舊版 SQL 中的資料表修飾符
通常,BigQuery 會在執行查詢時進行完整資料欄掃描。您可以在舊版 SQL 中,使用資料表修飾符執行更符合成本效益的資料子集查詢。無論何時讀取資料表都可以使用資料表修飾符,例如複製資料表、匯出資料表或使用 tabledata.list
列出資料時。
資料表修飾符支援相對和絕對 <time>
值。相對值由負數表示,絕對值由正數表示。舉例來說,-3600000
表示相對於目前時間的一小時前 (以毫秒為單位);3600000
表示 1970 年 1 月 1 日後的一小時 (以毫秒為單位)。
時間修飾符
時間修飾符 (舊稱「快照修飾符」) 會參照資料表在特定時間點的歷史資料。
語法
@<time>
- 指
<time>
的資料表歷來資料,以紀元後毫秒為單位。 <time>
必須是最近七天內,且大於或等於資料表的建立時間,但小於資料表的刪除或到期時間。@0
是特殊情況,指資料表可用的最舊資料。
時間修飾符也用於舊版 SQL 以外的環境。您可以在 bq cp
指令中使用這些修飾符,還原在七天內刪除的資料表。
範例
如要取得一小時前資料表的歷來資料,請執行下列操作:
相對值範例
#legacySQL
SELECT COUNT(*) FROM [PROJECT_ID:DATASET.TABLE@-3600000]
絕對值範例
取得一小時前的
<time>
:#legacySQL SELECT INTEGER(DATE_ADD(USEC_TO_TIMESTAMP(NOW()), -1, 'HOUR')/1000)
然後在以下查詢中替換
<time>
:#legacySQL SELECT COUNT(*) FROM [PROJECT_ID:DATASET.TABLE@time]
範圍修飾符
語法
@<time1>-<time2>
- 指
<time1>
和<time2>
之間新增的資料表資料,以紀元後毫秒為單位。 <time1>
和<time2>
必須在最近七天內。<time2>
是選用項目,預設為「現在」。
範例
相對值範例
如要取得前一小時和前半小時間新增的資料表資料:
#legacySQL
SELECT COUNT(*) FROM [PROJECT_ID:DATASET.TABLE@-3600000--1800000]
如要取得前 10 分鐘的資料:
#legacySQL
SELECT COUNT(*) FROM [PROJECT_ID:DATASET.TABLE@-600000-]
絕對值範例
如要取得前一小時和前半小時間新增的資料表資料:
取得一小時前的
<time1>
:#legacySQL SELECT INTEGER(DATE_ADD(USEC_TO_TIMESTAMP(NOW()), -1, 'HOUR')/1000)
取得半小時前的
<time2>
:#legacySQL SELECT INTEGER(DATE_ADD(USEC_TO_TIMESTAMP(NOW()), -30, 'MINUTE')/1000)
在下列查詢中取代
<time1>
和<time2>
:#legacySQL SELECT COUNT(*) FROM [PROJECT_ID:DATASET.TABLE@time1-time2]