שימוש במנהל התקן 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) חלות.
לפני שמתחילים
- חשוב לוודא שאתם מכירים את מנהלי ההתקנים של JDBC, את Apache Maven ואת החבילה
java.sql. - מוודאים שהמערכת מוגדרת עם סביבת זמן ריצה של Java (JRE) בגרסה 8.0 ואילך. מידע על בדיקת גרסת ה-JRE זמין במאמר אימות סביבת ה-JRE.
מאמתים את החיבור ל-BigQuery ורושמים את הפרטים הבאים, שבהם תשתמשו בהמשך כשתקימו חיבור עם מנהל ההתקן של JDBC ל-BigQuery. צריך לציין רק את המידע שמתאים לשיטת האימות שבה אתם משתמשים.
שיטת אימות פרטי אימות דוגמה מאפיין חיבור (להגדרה מאוחר יותר) חשבון שירות רגיל כתובת האימייל של חשבון השירות bq-jdbc-sa@mytestproject.iam.gserviceaccount.comOAuthServiceAcctEmailמפתח של חשבון שירות (אובייקט JSON) my-sa-keyOAuthPvtKeyקובץ מפתח של חשבון שירות קובץ המפתח של חשבון השירות (נתיב מלא) path/to/file/secret.jsonOAuthPvtKeyPathחשבון משתמש ב-Google מזהה לקוח 123-abc.apps.googleusercontent.comOAuthClientIdסוד לקוח _aB-C1D_E2fGh3Ij4kL5m6No7p8QR9sT0uVOAuthClientSecretטוקן גישה שנוצר מראש טוקן גישה ya29.a0AfH6SMCiH1L-x_yZOAuthAccessTokenטוקן רענון שנוצר מראש טוקן רענון 1/fFAGRNJru1FTz70BzhT3ZgOAuthRefreshTokenמזהה לקוח 123-abc.apps.googleusercontent.comOAuthClientIdסוד לקוח _aB-C1D_E2fGh3Ij4kL5m6No7p8QR9sT0uVOAuthClientSecretApplication Default Credentials ללא לא רלוונטי לא רלוונטי קובץ תצורה קובץ תצורה (אובייקט JSON או נתיב מלא) path/to/file/secret.jsonOAuthPvtKeyאובייקט הגדרת חשבון חיצוני אובייקט של הגדרת חשבון external_account_configuration_objectOAuthPvtKeyאחר מאפיין הקהל של קובץ ההגדרה של החשבון החיצוני //iam.googleapis.com/projects/my-project/locations/US-EAST1/workloadIdentityPools/my-pool-/providers/my-providerBYOID_AudienceUriאחזור טוקן וקובץ מידע על הסביבה {\"file\":\"/path/to/file\"}BYOID_CredentialSourceפרויקט של משתמש (רק אם משתמשים במאגר כוח עבודה) my_projectBYOID_PoolUserProjectה-URI להתחזות לחשבון שירות (רק אם משתמשים במאגר כוח אדם) my-saBYOID_SA_Impersonation_Uriאסימון Security Token Service שמבוסס על מפרט החלפת האסימונים urn:ietf:params:oauth:tokentype:id_tokenBYOID_SubjectTokenTypeנקודת קצה להחלפת טוקנים ב-Security Token Service https://sts.googleapis.com/v1/tokenBYOID_TokenUri
הגדרת סביבת הפיתוח
כדי להגדיר את סביבת הפיתוח עם מנהל התקן JDBC ל-BigQuery, מבצעים את הפעולות הבאות:
מורידים אחת מחבילות ה-JDBC הבאות:
- Uber JAR. קובץ JAR עם כל התלויות.
- Uber JAR עם הצללה. קובץ JAR מוצלל שכולל את כל התלויות.
- קובץ JAR דק עם יחסי תלות. קובץ ZIP שכולל קובץ JAR דק וכל התלויות.
מוסיפים את קובץ ה-JAR שהורדתם לנתיב המחלקות (classpath) כדי שהקומפיילר של Java וסביבת זמן הריצה יוכלו לאתר את מחלקות ה-JDBC הנדרשות. מידע על הוספת קובץ לנתיב המחלקות זמין במאמר בנושא הגדרת נתיב המחלקות.
מוסיפים את יחסי התלות הבאים לקובץ הבנייה:
<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>
אם אתם משתמשים בפרויקט Gradle, מוסיפים את השורות הבאות לקובץ ה-build:
dependencies { // ... other dependencies implementation files('path/to/file/google-jdbc-jar-with-dependencies.jar') }
יצירת חיבור
כדי ליצור חיבור בין אפליקציית Java לבין BigQuery באמצעות מנהל התקן JDBC ל-BigQuery, צריך לבצע את הפעולות הבאות:
מזהים את מחרוזת החיבור של מנהל ההתקן של 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;.... רשימה מלאה של מאפייני החיבור זמינה במאמר מאפייני חיבור.
-
מחברים את אפליקציית 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: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 |
נקודות קצה בהתאמה אישית כדי להחליף את נקודות הקצה הבאות:
|
לא רלוונטי | מחרוזת מופרדת בפסיקים | לא |
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 |
מספר שלם | לא |
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 |
סוג האימות. אחת מהאפשרויות הבאות:
|
-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 הרגילים.