Click here to view and discuss this page in DocCommentXchange. In the future, you will be sent there automatically.

SQL Anywhere 12.0.0 (Deutsch) » MobiLink - Erste Orientierung » Praktische Einführungen in MobiLink » Praktische Einführung: Java-Synchronisationslogik verwenden

 

Lektion 2: Klassenmethoden für Ereignisse festlegen

CustdbScripts.class wurde in der vorangehenden Lektion erstellt und umfasst die Methoden UploadInsert und DownloadCursor. Diese Methoden enthalten die Implementierungen der ULCustomer-Ereignisse upload_insert bzw. download_cursor.

In diesem Abschnitt legen Sie Klassenmethoden für Ereignisse auf Tabellenebene auf zwei verschiedenen Wegen fest:

  1. MobiLink-Projekt über Sybase Central erstellen.

    Verbinden Sie sich mit der CustDB-Datenbank über Sybase Central, ersetzen Sie das upload_insert SQL-Skript durch ein Java-Skript und legen Sie CustdbScripts.UploadInsert für die Verarbeitung des Ereignisses fest.

  2. Die gespeicherte Prozedur ml_add_java_table_script verwenden:

    Verbinden Sie sich mit der Datenbank CustDB mithilfe von Interactive SQL und führen ml_add_java_table_script aus, wobei Sie CustdbScripts.DownloadCursor für das Ereignis download_cursor festlegen.

 ♦  So erstellen Sie ein neues MobiLink-Projekt
  1. Wählen Sie Start » Programme » SQL Anywhere 12 » Administrationstools » Sybase Central.

  2. Wählen Sie im Menü Extras die Option MobiLink 12 » Neues Projekt.

  3. Im Feld Name geben Sie mljava_project ein.

  4. Im Feld Speicherort geben Sie C:\mljava ein und klicken dann auf Weiter.

  5. Aktivieren Sie die Option Dem Projekt eine konsolidierte Datenbank hinzufügen.

  6. Geben Sie im Feld Anzeigename der Datenbank mljava_db ein.

  7. Klicken Sie auf Bearbeiten. Das Fenster Mit einer allgemeinen ODBC-Datenbank verbinden erscheint.

  8. Klicken Sie im Feld ODBC-Datenquellenname auf Durchsuchen und wählen SQL Anywhere 12 CustDB.

  9. Klicken Sie auf OK und dann auf Speichern.

  10. Klicken Sie auf Fertig stellen.

  11. Klicken Sie auf OK.

Dieser Schritt verwendet Sybase Central, um eine Java-Methode als Skript für das upload_insert-Ereignis von ULCustomer festzulegen.

 ♦  So subskribieren Sie CustdbScripts.UploadInsert für das upload_insert-Ereignis der ULCustomer-Tabelle
  1. Wählen Sie aus dem Menü Ansicht die Option Ordner.

  2. Erweitern Sie im linken Fensterausschnitt von Sybase Central unter MobiLink 12 mljava_project, Konsolidierte Datenbanken, mljava_db, Synchronisierte Tabelle und dann ULCustomer.

  3. Wählen Sie im rechten Fensterausschnitt das custdb 12.0 upload_insert-Tabellenskript. Wählen Sie im Menü Bearbeiten die Option Löschen.

  4. Erstellen Sie ein neues upload_insert-Tabellenskript.

    1. Wählen Sie im Datei-Menü Neu » Tabellenskript.

    2. In der Liste Für welche Version soll das Tabellenskript erstellt werden? klicken Sie auf custdb 12.0.

    3. In der Liste Bei welchem Ereignis soll das Tabellenskript ausgeführt werden? klicken Sie auf upload_insert und dann auf Weiter.

    4. Wählen Sie Neue Skriptdefinition erstellen und dann Java.

    5. Klicken Sie auf Fertig stellen.

  5. Geben Sie den Java-Methodennamen zum Laden für das custdb 12.0 upload_insert-Tabellenskript ein.

    Im rechten Fensterausschnitt von Sybase Central verwenden Sie die folgende Java Skript für das upload_insert-Ereignis:

    CustdbScripts.UploadInsert
  6. Im Menü Datei wählen Sie Speichern, um das Skript zu speichern.

  7. Schließen Sie Sybase Central.

Als Alternative können Sie die gespeicherten Prozeduren ml_add_java_connection_script und ml_add_java_table_script verwenden. Die Verwendung dieser gespeicherten Prozeduren ist v.a. dann effizient, wenn Sie eine große Anzahl von Java-Methoden für die Verarbeitung von Synchronisationsereignissen einsetzen.

Siehe ml_add_java_connection_script-Systemprozedur und ml_add_java_table_script-Systemprozedur.

Im nächsten Abschnitt stellen Sie mithilfe von Interactive SQL eine Verbindung zu CustDB her und führen ml_add_java_table_script aus, indem Sie dem download_cursor-Ereignis CustdbScripts.DownloadCursor zuweisen.

 ♦  So legen Sie CustdbScripts.DownloadCursor() für das Ereignis ULCustomer download_cursor fest
  1. Verbinden Sie sich mit der Beispieldatenbank mittels Interactive SQL.

    1. Wählen Sie Start » Programme » SQL Anywhere 12 » Administrationstools » Interactive SQL oder führen Sie folgenden Befehl aus:

      dbisql
    2. Klicken Sie auf ODBC-Datenquellenname und geben Sie SQL Anywhere 12 CustDB ein.

    3. Klicken Sie auf Verbinden.

  2. Führen Sie folgendes SQL-Skript in Interactive SQL aus:

    CALL ml_add_java_table_script(
        'custdb 12.0',
        'ULCustomer',
        'download_cursor',
        'CustdbScripts.DownloadCursor');
    COMMIT;

    Im Folgenden finden Sie eine Beschreibung der einzelnen Parameter:

    Parameter Beschreibung
    custdb 12.0 Die Skriptversion
    ULCustomer Die synchronisierte Tabelle
    download_cursor Der Ereignisname
    CustdbScripts.DownloadCursor Die vollständig qualifizierte Java-Methode
    Hinweis

    Ihr hochgeladenes download_cursor-Skript erscheint möglicherweise nicht in Sybase Central. Um die jüngsten Änderungen am MobiLink-Projekt in Sybase Central anzuzeigen, klicken Sie auf das Ansicht-Menü und wählen Alles aktualisieren.

  3. Schließen Sie Interactive SQL.

In dieser Lektion haben Sie Java-Methoden für die Verarbeitung von ULCustomer-Tabellenereignissen festgelegt. In der nächsten Lektion stellen Sie sicher, dass der MobiLink-Server die richtigen Klassendateien und die MobiLink-Server-API lädt.

 Weitere Hinweise