שימוש במנהל התקן JDBC ל-BigQuery

מנהל ההתקן (driver) של Java Database Connectivity‏ (JDBC) ל-BigQuery מקשר את אפליקציות Java ל-BigQuery, ומאפשר לכם להשתמש בתכונות של BigQuery עם כלי התשתית המועדפים שלכם. כדי לחבר אפליקציות שאינן Java ל-BigQuery, משתמשים במנהל ההתקן Simba Open Database Connectivity ‏ (ODBC) ל-BigQuery.

מגבלות

מגבלות השימוש בדרייבר JDBC ל-BigQuery:

  • הדרייבר ספציפי ל-BigQuery ואי אפשר להשתמש בו עם מוצרים או שירותים אחרים.
  • סוג הנתונים INTERVAL לא נתמך ב-BigQuery Storage Read API.
  • כל המגבלות של שפת טיפול בנתונים (DML) חלות.

לפני שמתחילים

  1. חשוב לוודא שאתם מכירים את מנהלי ההתקנים של JDBC, את Apache Maven ואת החבילה java.sql.
  2. מוודאים שהמערכת מוגדרת עם סביבת זמן ריצה של Java‏ (JRE) בגרסה 8.0 ואילך. מידע על בדיקת גרסת ה-JRE זמין במאמר אימות סביבת ה-JRE.
  3. מאמתים את החיבור ל-BigQuery ורושמים את הפרטים הבאים, שבהם תשתמשו בהמשך כשתקימו חיבור עם מנהל ההתקן של JDBC ל-BigQuery. צריך לציין רק את המידע שמתאים לשיטת האימות שבה אתם משתמשים.

    שיטת אימות פרטי אימות דוגמה מאפיין חיבור (להגדרה מאוחר יותר)
    חשבון שירות רגיל כתובת האימייל של חשבון השירות bq-jdbc-sa@mytestproject.iam.gserviceaccount.com OAuthServiceAcctEmail
    מפתח של חשבון שירות (אובייקט JSON) my-sa-key OAuthPvtKey
    קובץ מפתח של חשבון שירות קובץ המפתח של חשבון השירות (נתיב מלא) path/to/file/secret.json OAuthPvtKeyPath
    חשבון משתמש ב-Google מזהה לקוח 123-abc.apps.googleusercontent.com OAuthClientId
    סוד לקוח _aB-C1D_E2fGh3Ij4kL5m6No7p8QR9sT0uV OAuthClientSecret
    טוקן גישה שנוצר מראש טוקן גישה ya29.a0AfH6SMCiH1L-x_yZ OAuthAccessToken
    טוקן רענון שנוצר מראש טוקן רענון 1/fFAGRNJru1FTz70BzhT3Zg OAuthRefreshToken
    מזהה לקוח 123-abc.apps.googleusercontent.com OAuthClientId
    סוד לקוח _aB-C1D_E2fGh3Ij4kL5m6No7p8QR9sT0uV OAuthClientSecret
    Application Default Credentials ללא לא רלוונטי לא רלוונטי
    קובץ תצורה קובץ תצורה (אובייקט JSON או נתיב מלא) path/to/file/secret.json OAuthPvtKey
    אובייקט הגדרת חשבון חיצוני אובייקט של הגדרת חשבון external_account_configuration_object OAuthPvtKey
    אחר מאפיין הקהל של קובץ ההגדרה של החשבון החיצוני //iam.googleapis.com/projects/my-project/locations/US-EAST1/workloadIdentityPools/my-pool-/providers/my-provider BYOID_AudienceUri
    אחזור טוקן וקובץ מידע על הסביבה {\"file\":\"/path/to/file\"} BYOID_CredentialSource
    פרויקט של משתמש (רק אם משתמשים במאגר כוח עבודה) my_project BYOID_PoolUserProject
    ה-URI להתחזות לחשבון שירות (רק אם משתמשים במאגר כוח אדם) my-sa BYOID_SA_Impersonation_Uri
    אסימון Security Token Service שמבוסס על מפרט החלפת האסימונים urn:ietf:params:oauth:tokentype:id_token BYOID_SubjectTokenType
    נקודת קצה להחלפת טוקנים ב-Security Token Service https://sts.googleapis.com/v1/token BYOID_TokenUri

הגדרת סביבת הפיתוח

כדי להגדיר את סביבת הפיתוח עם מנהל התקן JDBC ל-BigQuery, מבצעים את הפעולות הבאות:

  1. מורידים אחת מחבילות ה-JDBC הבאות:

  2. מוסיפים את קובץ ה-JAR שהורדתם לנתיב המחלקות (classpath) כדי שהקומפיילר של Java וסביבת זמן הריצה יוכלו לאתר את מחלקות ה-JDBC הנדרשות. מידע על הוספת קובץ לנתיב המחלקות זמין במאמר בנושא הגדרת נתיב המחלקות.

  3. מוסיפים את יחסי התלות הבאים לקובץ הבנייה:

    <dependency>
        <groupId>com.google.cloud</groupId>
        <artifactId>google-cloud-bigquery-jdbc</artifactId>
        <version>0.0.1</version>
        <scope>system</scope>
        <systemPath>path/to/file/google-jdbc-jar-with-dependencies.jar</systemPath>
    </dependency>
  4. אם אתם משתמשים בפרויקט Gradle, מוסיפים את השורות הבאות לקובץ ה-build:

    dependencies {
    // ... other dependencies
    implementation files('path/to/file/google-jdbc-jar-with-dependencies.jar')
    }

יצירת חיבור

כדי ליצור חיבור בין אפליקציית Java לבין BigQuery באמצעות מנהל התקן JDBC ל-BigQuery, צריך לבצע את הפעולות הבאות:

  1. מזהים את מחרוזת החיבור של מנהל ההתקן של JDBC ל-BigQuery. המחרוזת הזו כוללת את כל המידע שנדרש כדי ליצור חיבור בין אפליקציית Java לבין BigQuery. מחרוזת החיבור היא בפורמט הבא:

    jdbc:bigquery://HOST:PORT;ProjectId=PROJECT_ID;OAuthType=AUTH_TYPE;AUTH_PROPS;OTHER_PROPS

    מחליפים את מה שכתוב בשדות הבאים:

    • HOST: כתובת ה-DNS או כתובת ה-IP של השרת.
    • PORT: מספר יציאת ה-TCP.
    • PROJECT_ID: מזהה הפרויקט ב-BigQuery.
    • AUTH_TYPE: מספר שמציין את סוג האימות שבו השתמשתם. אחת מהאפשרויות הבאות:
      • 0: לאימות של חשבון שירות (סטנדרטי וקובץ מפתח)
      • 1: לאימות של חשבון משתמש ב-Google
      • 2: לאימות של אסימון רענון או אסימון גישה שנוצרו מראש
      • 3: לאימות Application Default Credential
      • 4: לשיטות אימות אחרות
    • AUTH_PROPS: פרטי האימות שרשמתם כשביצעתם אימות ל-BigQuery, שמופיעים בפורמט property_1=value_1; property_2=value_2;... – למשל, OAuthPvtKeyPath=path/to/file/secret.json, אם ביצעתם אימות באמצעות קובץ מפתח של חשבון שירות.
    • OTHER_PROPS (אופציונלי): מאפייני חיבור נוספים למנהל ההתקן של JDBC, שמופיעים בפורמט property_1=value_1; property_2=value_2;.... רשימה מלאה של מאפייני החיבור זמינה במאמר מאפייני חיבור.
  2. מחברים את אפליקציית Java למנהל ההתקן של JDBC ל-BigQuery באמצעות המחלקה DriverManager או DataSource.

    • להתחבר לכיתה DriverManager:

      import java.sql.Connection;
      import java.sql.DriverManager;
      
      private static Connection getJdbcConnectionDM(){
        Connection connection = DriverManager.getConnection(CONNECTION_STRING);
        return connection;
      }

      מחליפים את CONNECTION_STRING במחרוזת החיבור מהשלב הקודם.

    • להתחבר לכיתה DataSource:

      import com.google.cloud.bigquery.jdbc.DataSource;
      import java.sql.Connection;
      import java.sql.SQLException;
      
      private static public Connection getJdbcConnectionDS() throws SQLException {
        Connection connection = null;
        DataSource dataSource = new com.google.cloud.bigquery.jdbc.DataSource();
        dataSource.setURL(CONNECTION_STRING);
        connection = dataSource.getConnection();
        return connection;
      }

      מחליפים את CONNECTION_STRING במחרוזת החיבור מהשלב הקודם.

      במחלקה DataSource יש גם שיטות setter שבהן אפשר להשתמש כדי להגדיר מאפייני חיבור, במקום לכלול אותם במחרוזת החיבור. לדוגמה:

      private static Connection getConnection() throws SQLException {
        DataSource ds = new DataSource();
        ds.setURL(jdbc:bigquery://https://www.googleapis.com/bigquery/v2:443;);
        ds.setAuthType(3);  // Application Default Credentials
        ds.setProjectId("MyTestProject");
        ds.setEnableHighThroughputAPI(true);
        ds.setLogLevel("6");
        ds.setUseQueryCache(false);
        return ds.getConnection();
      }

מאפייני החיבור

מאפייני החיבור של דרייבר JDBC הם פרמטרים של הגדרה שכוללים במחרוזת החיבור או מעבירים דרך שיטות setter כשמקימים חיבור למסד נתונים. מנהל ההתקן של JDBC ל-BigQuery תומך במאפייני החיבור הבאים.

נכס חיבור תיאור ערך ברירת מחדל סוג הנתונים חובה
AdditionalProjects פרויקטים שלנהג יש גישה אליהם לשאילתות ולפעולות מטא-נתונים, בנוסף לפרויקט הראשי שמוגדר על ידי המאפיין ProjectId. לא רלוונטי מחרוזת מופרדת בפסיקים לא
AllowLargeResults קובע אם הדרייבר מעבד תוצאות של שאילתות שגדולות מ-128MB, כשהמאפיין QueryDialect מוגדר ל-BIG_QUERY. אם המאפיין QueryDialect מוגדר לערך SQL, מנהל ההתקן תמיד מעבד תוצאות גדולות של שאילתות. TRUE בוליאני לא
BYOID_AudienceUri מאפיין הקהל בקובץ התצורה של חשבון חיצוני. מאפיין הקהל יכול להכיל את שם המשאב של מאגר הזהויות של עומסי העבודה או של מאגר כוח העבודה, וגם את מזהה הספק במאגר הזה. לא רלוונטי String רק כשOAuthType=4
BYOID_CredentialSource אחזור הטוקן ופרטי הסביבה. לא רלוונטי String רק כשOAuthType=4
BYOID_PoolUserProject פרויקט המשתמש כשמשתמשים במאגר כוח עבודה לאימות. לא רלוונטי String רק כשמשתמשים ב-OAuthType=4 ובמאגר כוח העבודה
BYOID_SA_Impersonation_Uri ה-URI של ההתחזות לחשבון השירות כשמשתמשים במאגר כוח אדם לצורך אימות. לא רלוונטי String רק כשמשתמשים ב-OAuthType=4 ובמאגר כוח העבודה
BYOID_SubjectTokenType אסימון Security Token Service שמבוסס על מפרט החלפת האסימונים. אחת מהאפשרויות הבאות:
  • urn:ietf:params:oauth:token-type:jwt
  • urn:ietf:params:oauth:token-type:id_token
  • urn:ietf:params:oauth:token-type:saml2
  • urn:ietf:params:aws:token-type:aws4_request
urn:ietf:params:oauth:tokentype:id_token String רק כשOAuthType=4
BYOID_TokenUri נקודת הקצה של החלפת האסימון של Security Token Service. https://sts.googleapis.com/v1/token String לא
ConnectionPoolSize גודל מאגר החיבורים, אם מאגר החיבורים מופעל. 10 ארוכה לא
DefaultDataset מערך הנתונים שמשמש את המערכת כשלא מצוין מערך נתונים בשאילתה. לא רלוונטי String לא
EnableHighThroughputAPI קובעת אם אפשר להשתמש ב-Storage Read API. כדי להשתמש ב-Storage Read API, צריך להגדיר את המאפיינים HighThroughputActivationRatio ו- HighThroughputMinTableSize לערך TRUE. FALSE בוליאני לא
EnableSession קובע אם החיבור מתחיל סשן. אם הערך הוא TRUE, מזהה הסשן מועבר לכל השאילתות הבאות. FALSE בוליאני לא
EnableWriteAPI קובעת אם אפשר להשתמש ב-Storage Write API. צריך להגדיר אותו לערך TRUE כדי להפעיל הוספה בכמות גדולה. FALSE בוליאני לא
EndpointOverrides נקודות קצה בהתאמה אישית כדי להחליף את נקודות הקצה הבאות:
  • BIGQUERY=https://bigquery.googleapis.com
  • READ_API=https://bigquerystorage.googleapis.com
  • OAUTH2=https://oauth2.googleapis.com
  • STS=https://sts.googleapis.com
לא רלוונטי מחרוזת מופרדת בפסיקים לא
FilterTablesOnDefaultDataset קובע את היקף המטא-נתונים שמוחזרים על ידי השיטות DatabaseMetaData.getTables() ו- DatabaseMetaData.getColumns(). אם הערך הוא FALSE, לא מתבצע סינון. כדי להפעיל את הסינון, צריך להגדיר גם את המאפיין DefaultDataset. FALSE בוליאני לא
HighThroughputActivationRatio סף מספר הדפים בתגובה לשאילתה. אם חורגים מהמספר הזה, ומתקיימים התנאים של EnableHighThroughputAPI ושל HighThroughputMinTableSize, הנהג מתחיל להשתמש ב-Storage Read API. 2 מספר שלם לא
HighThroughputMinTableSize סף מספר השורות בתגובה לשאילתה. אם המספר הזה חורג מהמגבלה, והתנאים של EnableHighThroughputAPI ושל HighThroughputActivationRatio מתקיימים, הנהג מתחיל להשתמש ב-Storage Read API. 100 מספר שלם לא
JobCreationMode קובע אם השאילתות מופעלות עם משימות או בלי משימות. ערך של 1 מציין שהמערכת יוצרת משימות לכל שאילתה, וערך של 2 מציין שאפשר להריץ שאילתות בלי משימות. 2 מספר שלם לא
JobTimeout הזמן הקצוב לתפוגה של המשימה (בשניות) שאחריו המשימה מבוטלת בשרת. 0 ארוכה לא
KMSKeyName השם של מפתח ה-KMS להצפנת נתונים. לא רלוונטי String לא
Labels תוויות שמשויכות לשאילתה כדי לארגן ולקבץ משימות של שאילתות. לא רלוונטי ‫Map<String, String> לא
LargeResultDataset ערכת הנתונים של היעד לתוצאות של שאילתות גדולות, רק אם המאפיין LargeResultTable מוגדר. כשמגדירים את המאפיין הזה, פעולות כתיבה של נתונים מדלגות על מטמון התוצאות ומפעילות חיוב על כל שאילתה, גם אם התוצאות קטנות. _google_jdbc String לא
LargeResultsDatasetExpirationTime משך החיים של כל הטבלאות במערך נתונים גדול של תוצאות, באלפיות השנייה. המערכת מתעלמת מהמאפיין הזה אם כבר הוגדר לערכת הנתונים זמן תפוגה שמוגדר כברירת מחדל. 3600000 ארוכה לא
LargeResultTable טבלת היעד לתוצאות של שאילתות גדולות, רק אם המאפיין LargeResultDataset מוגדר. כשמגדירים את הנכס הזה, פעולות כתיבה של נתונים מדלגות על מטמון התוצאות ומפעילות חיוב על כל שאילתה, גם אם התוצאות קטנות. temp_table... String לא
ListenerPoolSize גודל מאגר המאזינים, אם מאגר החיבורים מופעל. 10 ארוכה לא
Location המיקום שבו נוצרים מערכי נתונים או נשלחות שאילתות לגביהם. אם לא מגדירים את המאפיין הזה, BigQuery קובע את המיקום באופן אוטומטי. לא רלוונטי String לא
LogLevel רמת הפירוט שמתועדת על ידי חבילת java.util.logging במהלך אינטראקציות עם מסד הנתונים. הרישום ביומן יכול להשפיע על הביצועים, ולכן כדאי להפעיל אותו רק באופן זמני כדי לתעד בעיה. אחת מהאפשרויות הבאות:
  • 0: הרמה OFF
  • 1: הרמה SEVERE
  • 2: הרמה WARNING
  • 3: הרמה INFO
  • 4: הרמה CONFIG
  • 5: הרמה FINE
  • 6: הרמה FINER
  • 7: הרמה FINEST
  • 8: הרמה ALL
0 מספר שלם לא
LogPath הספרייה שבה נכתבים קובצי היומן. לא רלוונטי String לא
MaximumBytesBilled מכסת הבייטים לחיוב. אם השאילתה תחרוג ממגבלת הבייטים לחיוב, הרצת השאילתה תיכשל (החשבון לא יחויב). 0 ארוכה לא
MaxResults המספר המקסימלי של תוצאות בכל דף. 10000 ארוכה לא
MetaDataFetchThreadCount מספר השרשורים שמשמשים לשיטות של מטא-נתונים של מסד נתונים. 32 מספר שלם לא
OAuthAccessToken אסימון הגישה שמשמש לאימות של אסימון גישה שנוצר מראש. לא רלוונטי String רק כשOAUTH_TYPE=2
OAuthClientId מזהה הלקוח לאימות של אסימון רענון שנוצר מראש ולאימות של חשבון משתמש. לא רלוונטי String רק כשלוחצים על OAUTH_TYPE=1 או על OAUTH_TYPE=2
OAuthClientSecret סוד הלקוח לאימות טוקן רענון שנוצר מראש ולאימות חשבון משתמש. לא רלוונטי String רק כשלוחצים על OAUTH_TYPE=1 או על OAUTH_TYPE=2
OAuthP12Password הסיסמה לקובץ המפתח PKCS12. notasecret String לא
OAuthPvtKey המפתח של חשבון השירות כשמשתמשים באימות של חשבון שירות. הערך הזה יכול להיות אובייקט גולמי של קובץ מפתח JSON או נתיב לקובץ מפתח JSON. לא רלוונטי String רק אם OAUTH_TYPE=0 והערך של OAuthPvtKeyPath לא מוגדר
OAuthPvtKeyPath הנתיב למפתח של חשבון השירות כשמשתמשים באימות של חשבון שירות. לא רלוונטי String רק אם הערכים של OAUTH_TYPE=0, OAuthPvtKey ו-OAuthServiceAcctEmail לא מוגדרים
OAuthRefreshToken אסימון הרענון לאימות באמצעות אסימון רענון שנוצר מראש. לא רלוונטי String רק כשOAUTH_TYPE=2
OAuthServiceAcctEmail כתובת האימייל של חשבון השירות כשמשתמשים באימות של חשבון שירות. לא רלוונטי String רק אם OAUTH_TYPE=0 והערך של OAuthPvtKeyPath לא מוגדר
OAuthType סוג האימות. אחת מהאפשרויות הבאות:
  • 0: אימות של חשבון שירות
  • 1: אימות של חשבון המשתמש
  • 2: אימות באמצעות אסימון גישה או אסימון רענון שנוצר מראש
  • 3: אימות Application Default Credential
  • 4: שיטות אימות אחרות
-1 מספר שלם כן
PartnerToken טוקן שמשמש שותפים של Google Cloud למעקב אחרי השימוש במנהל ההתקן. לא רלוונטי String לא
ProjectId מזהה הפרויקט שמוגדר כברירת מחדל לדרייבר. הפרויקט הזה משמש להרצת שאילתות, והחיוב מתבצע לפי השימוש במשאבים. אם לא מגדירים את מזהה הפרויקט, הדרייבר מסיק אותו. לא רלוונטי String לא, אבל מומלץ מאוד
ProxyHost שם המארח או כתובת ה-IP של שרת proxy שדרכו מנותב חיבור ה-JDBC. לא רלוונטי String לא
ProxyPort מספר היציאה שבה שרת ה-proxy מאזין לחיבורים. לא רלוונטי String לא
ProxyPwd הסיסמה לאימות כשמתחברים דרך שרת proxy שנדרש לכך. לא רלוונטי String לא
ProxyUid שם המשתמש לאימות כשמתחברים דרך שרת proxy שנדרש לכך. לא רלוונטי String לא
QueryDialect דיאלקט ה-SQL להרצת השאילתה. מומלץ מאוד להשתמש ב-SQL ל-GoogleSQL וב-BIG_QUERY ל-SQL מדור קודם. SQL String לא
QueryProperties מאפייני חיבור REST שמשמשים להתאמה אישית של התנהגות השאילתה. לא רלוונטי ‫Map<String, String> לא
RequestGoogleDriveScope מוסיף היקף גישה לקריאה בלבד ב-Drive לחיבור כשהערך הוא 1. 0 מספר שלם לא
RetryInitialDelay מגדיר את ההשהיה (בשניות) לפני הניסיון החוזר הראשון. 0 ארוכה לא
RetryMaxDelay הגדרת המגבלה המקסימלית (בשניות) של ההשהיה בין ניסיונות חוזרים. 0 ארוכה לא
ServiceAccountImpersonationChain רשימה של כתובות אימייל של חשבונות שירות בשרשרת ההתחזות, שמופרדות באמצעות פסיקים. לא רלוונטי String לא
ServiceAccountImpersonationEmail כתובת האימייל של חשבון השירות שאליו רוצים להתחזות. לא רלוונטי String לא
ServiceAccountImpersonationScopes רשימה של היקפי הרשאות OAuth2 שמופרדים באמצעות פסיקים, לשימוש עם החשבון המזויף. https://www.googleapis.com/auth/bigquery String לא
ServiceAccountImpersonationTokenLifetime משך החיים של האסימון של החשבון שהתבצעה אליו התחזות (בשניות). 3600 מספר שלם לא
SSLTrustStore הנתיב המלא אל Java TrustStore שמכיל אישורי רשות אישורים (CA) מהימנים. הדרייבר משתמש במאגר האישורים הזה כדי לאמת את הזהות של השרת במהלך לחיצת היד של SSL/TLS. לא רלוונטי String לא
SSLTrustStorePwd הסיסמה ל-Java TrustStore שצוינה במאפיין SSLTrustStore. לא רלוונטי String רק אם מאגר האישורים של Java מוגן בסיסמה
SWA_ActivationRowCount הסף של executeBatch insert שורות, שאם חורגים ממנו, המחבר עובר ל-Storage Write API. 3 מספר שלם לא
SWA_AppendRowCount הגודל של זרם הכתיבה. 1000 מספר שלם לא
Timeout משך הזמן בשניות שבו המחבר מנסה שוב לבצע קריאה ל-API שנכשלה לפני שחלף הזמן הקצוב לתפוגה. 0 ארוכה לא
UniverseDomain הדומיין ברמה העליונה שמשויך ל Google Cloud משאבים של הארגון. googleapis.com String לא
UnsupportedHTAPIFallback ההגדרה קובעת אם המחבר יחזור ל-REST API (כשהערך הוא TRUE) או יחזיר שגיאה (כשהערך הוא FALSE). TRUE בוליאני לא
UseQueryCache הפעלת שמירה במטמון של שאילתות. TRUE בוליאני לא

הרצת שאילתות באמצעות הדרייבר

אחרי שהאפליקציה שלכם ב-Java מחוברת ל-BigQuery דרך מנהל ההתקן JDBC, אתם יכולים להריץ שאילתות בסביבת הפיתוח שלכם דרך תהליך JDBC רגיל. כל המכסות והמגבלות של BigQuery חלות.

מיפוי סוגי נתונים

כשמריצים שאילתות דרך מנהל ההתקן של JDBC ל-BigQuery, מתבצע מיפוי של סוגי הנתונים הבאים:

סוג GoogleSQL סוג Java
ARRAY Array
BIGNUMERIC BigDecimal
BOOL Boolean
BYTES byte[]
DATE Date
DATETIME String
FLOAT64 Double
GEOGRAPHY String
INT64 Long
INTERVAL String
JSON String
NUMERIC BigDecimal
STRING String
STRUCT Struct
TIME Time
TIMESTAMP Timestamp

דוגמאות

בקטעים הבאים מופיעות דוגמאות לשימוש בתכונות של BigQuery באמצעות מנהל ההתקן JDBC ל-BigQuery.

פרמטרים תלויי מיקום

בדוגמה הבאה מריצים שאילתה עם פרמטר תלוי מיקום:

PreparedStatement preparedStatement = connection.prepareStatement(
    "SELECT * FROM MyTestTable where testColumn = ?");
preparedStatement.setString(1, "string2");
ResultSet resultSet = statement.executeQuery(selectQuery);

רשומות בתוך רשומות ורשומות חוזרות

בדוגמה הבאה מוצגת שאילתה של רשומת הבסיס של נתוני Struct:

ResultSet resultSet = statement.executeQuery("SELECT STRUCT(\"Adam\" as name, 5 as age)");
    resultSet.next();
    Struct obj = (Struct) resultSet.getObject(1);
    System.out.println(obj.toString());

הדרייבר מחזיר את רשומת הבסיס כאובייקט struct או כייצוג מחרוזת של אובייקט JSON. התוצאה אמורה להיראות כך:

{
  "v": {
    "f": [
      {
        "v": "Adam"
      },
      {
        "v": "5"
      }
    ]
  }
}

בדוגמה הבאה מוצגת שאילתה לגבי רכיבי המשנה של אובייקט Struct:

ResultSet resultSet = statement.executeQuery("SELECT STRUCT(\"Adam\" as name, 5 as age)");
    resultSet.next();
    Struct structObject = (Struct) resultSet.getObject(1);
    Object[] structComponents = structObject.getAttributes();
    for (Object component : structComponents){
      System.out.println(component.toString());
    }

הדוגמה הבאה מציגה שאילתה על מערך רגיל של נתונים חוזרים, ואז בודקת את התוצאה:

// Execute Query
ResultSet resultSet = statement.executeQuery("SELECT [1,2,3]");
resultSet.next();
Object[] arrayObject = (Object[]) resultSet.getArray(1).getArray();

// Verify Result
int count =0;
for (; count < arrayObject.length; count++) {
  System.out.println(arrayObject[count]);
}

בדוגמה הבאה מבוצעת שאילתה על Struct מערך של נתונים חוזרים, ואז מאומתת התוצאה:

// Execute Query
ResultSet resultSet = statement.executeQuery("SELECT "
    + "[STRUCT(\"Adam\" as name, 12 as age), "
    + "STRUCT(\"Lily\" as name, 17 as age)]");

Struct[] arrayObject = (Struct[]) resultSet.getArray(1).getArray();

// Verify Result
for (int count =0; count < arrayObject.length; count++) {
  System.out.println(arrayObject[count]);
}

הוספה בכמות גדולה

בדוגמה הבאה מבוצעת פעולת הוספה בכמות גדולה באמצעות השיטה executeBatch.

Connection conn = DriverManager.getConnection(connectionUrl);
PreparedStatement statement = null;
Statement st = conn.createStatement();
final String insertQuery = String.format(
        "INSERT INTO `%s.%s.%s` "
      + " (StringField, IntegerField, BooleanField) VALUES(?, ?, ?);",
        DEFAULT_CATALOG, DATASET, TABLE_NAME);

statement = conn.prepareStatement(insertQuery1);

for (int i=0; i<2000; ++i) {
      statement.setString(1, i+"StringField");
      statement.setInt(2, i);
      statement.setBoolean(3, true);
      statement.addBatch();
}

statement.executeBatch();

תמחור

אפשר להוריד את מנהל ההתקן של JDBC ל-BigQuery ללא עלות, ולא צריך רישיונות נוספים כדי להשתמש במנהלי ההתקן. עם זאת, כשמשתמשים במנהל ההתקן, חלים תעריפי BigQuery הרגילים.

המאמרים הבאים