Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/viant/bgc
Datastore Connectivity for BigQuery in go
https://github.com/viant/bgc
Last synced: 6 days ago
JSON representation
Datastore Connectivity for BigQuery in go
- Host: GitHub
- URL: https://github.com/viant/bgc
- Owner: viant
- License: apache-2.0
- Created: 2016-06-13T20:24:26.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-03-17T20:59:48.000Z (9 months ago)
- Last Synced: 2024-07-31T20:50:04.449Z (4 months ago)
- Language: Go
- Size: 121 KB
- Stars: 22
- Watchers: 12
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go - bgc - Datastore Connectivity for BigQuery for go. (Database Drivers / Relational Database Drivers)
- awesome-go-storage - bgc - Datastore Connectivity for BigQuery for go. (Database Drivers)
- awesome-go - bgc - Datastore Connectivity for BigQuery in go - ★ 9 (Database Drivers)
- awesome-go-extra - bgc - 06-13T20:24:26Z|2020-02-13T15:00:33Z| (Generators / Relational Database Drivers)
- awesome-go-storage - bgc - Datastore Connectivity for BigQuery for go. (Database Drivers)
README
# Datastore Connectivity for BigQuery (bgc)
[![Datastore Connectivity library for BigQuery in Go.](https://goreportcard.com/badge/github.com/viant/bgc)](https://goreportcard.com/report/github.com/viant/bgc)
[![GoDoc](https://godoc.org/github.com/viant/bgc?status.svg)](https://godoc.org/github.com/viant/bgc)This library is compatible with Go 1.5+
Please refer to [`CHANGELOG.md`](CHANGELOG.md) if you encounter breaking changes.
- [Usage](#Usage)
- [License](#License)
- [Credits and Acknowledgements](#Credits-and-Acknowledgements)This library uses SQL mode and streaming API to insert data as default.
To use legacy SQL please use the following /* USE LEGACY SQL */ hint, in this case you will not be able to fetch repeated and nested fields.#### Configuration parameters
###### insertMethod
To control insert method just provide config.parameters with the following value:
_table_name_.insertMethod = "load"Note that if streaming is used, currently UPDATE and DELETE statements are not supported.
###### insertIdColumn
For streaming you can specify which column to use as insertId with the following config.params
_table_name_.insertMethod = "stream"
_table_name_.insertIdColumn = "sessionId"###### streamBatchCount
streamBatchCount controls row count in batch (default 9999)
###### insertWaitTimeoutInMs
When inserting data data this library checks upto 60 sec if data has been added.
To control this behaviour you can set insertWaitTimeoutInMs (default 60 sec)To disable this mechanism set:
insertWaitTimeoutInMs: -1###### insertMaxRetires
Retries insert when 503 internal error
###### datasetId
Default dataset
###### pageSize
Default 500
The maximum number of rows of data to return per page of results.
In addition to this limit, responses are also limited to 10 MB.## Credentials
1. Google secrets for service account
a) set GOOGLE_APPLICATION_CREDENTIALS environment variable
b) credential can be a name with extension of the JSON secret file placed into ~/.secret/ folder
config.yaml
```yaml
driverName: bigquery
credentials: bq # place your big query secret json to ~/.secret/bg.json
parameters:
datasetId: myDataset
```c) full URL to secret file
config.yaml
```yaml
driverName: bigquery
credentials: file://tmp/secret/mySecret.json
parameters:
datasetId: myDataset
```[Secret file](https://github.com/viant/toolbox/blob/master/cred/config.go) has to specify the following attributes:
````go
type Config struct {
//google cloud credential
ClientEmail string `json:"client_email,omitempty"`
TokenURL string `json:"token_uri,omitempty"`
PrivateKey string `json:"private_key,omitempty"`
PrivateKeyID string `json:"private_key_id,omitempty"`
ProjectID string `json:"project_id,omitempty"`
}
````2. Private key (pem)
config.yaml
```yaml
driverName: bigquery
credentials: bq # place your big query secret json to ~/.secret/bg.json
parameters:
serviceAccountId: "***@developer.gserviceaccount.com"
datasetId: MyDataset
projectId: spheric-arcadia-98015
privateKeyPath: /tmp/secret/bq.pem
```## Usage:
The following is a very simple example of Reading and Inserting data
```go
package main
import (
"github.com/viant/bgc"
"github.com/viant/dsc"
"time"
"fmt"
"log"
)type MostLikedCity struct {
City string
Visits int
Souvenirs []string
}type Traveler struct {
Id int
Name string
LastVisitTime time.Time
Achievements []string
MostLikedCity MostLikedCity
VisitedCities []struct {
City string
Visits int
}
}func main() {
config, err := dsc.NewConfigWithParameters("bigquery", "",
"bq", // google cloud secret placed in ~/.secret/bg.json
map[string]string{
"datasetId":"MyDataset",
})if err != nil {
log.Fatal(err)
}
factory := dsc.NewManagerFactory()
manager, err := factory.Create(config)
if err != nil {
log.Fatalf("Failed to create manager %v", err)
}
traveler := Traveler{}
success, err := manager.ReadSingle(&traveler, " SELECT id, name, lastVisitTime, visitedCities, achievements, mostLikedCity FROM travelers WHERE id = ?", []interface{}{4}, nil)
if err != nil {
panic(err.Error())
}travelers := make([]Traveler, 0)
err:= manager.ReadAll(&interest, "SELECT iid, name, lastVisitTime, visitedCities, achievements, mostLikedCity",nil, nil)
if err != nil {
panic(err.Error())
}// ...
inserted, updated, err := manager.PersistAll(&travelers, "travelers", nil)
if err != nil {
panic(err.Error())
}
// ...
//Custom reading handler with reading query info type to get CacheHit, TotalRows, TotalBytesProcessed
var resultInfo = &bgc.QueryResultInfo{}
var perf = make(map[string]int)
err = manager.ReadAllWithHandler(`SELECT DATE(date), COUNT(*) FROM performance_agg WHERE DATE(date) = ? GROUP BY 1`, []interface{}{
"2018-05-03",
resultInfo,
}, func(scanner dsc.Scanner) (toContinue bool, err error) {
var date string
var count int
err = scanner.Scan(&date, &count)
if err != nil {
return false, err
}
perf[date] = count
return true, nil
})
log.Printf("cache: %v, rows: %v, bytes: %v", resultInfo.CacheHit, resultInfo.TotalRows, resultInfo.TotalBytesProcessed)
dialect := dsc.GetDatastoreDialect(config.DriverName)
DDL, err := dialect.ShowCreateTable(manager, "performance_agg")
fmt.Printf("%v %v\n", DDL, err)
}
```## GoCover
[![GoCover](https://gocover.io/github.com/viant/bgc)](https://gocover.io/github.com/viant/bgc)
The source code is made available under the terms of the Apache License, Version 2, as stated in the file `LICENSE`.
Individual files may be made available under their own specific license,
all compatible with Apache License, Version 2. Please see individual files for details.## Credits and Acknowledgements
**Library Author:** Adrian Witas
**Contributors:** Mikhail Berlyant