Comments (2)
Have you tried running INSTALL parquet; LOAD parquet
beforehand like in https://github.com/marcboeker/go-duckdb/blob/master/duckdb_test.go#L910-L912?
from go-duckdb.
Thanks for the pointer. I am able to follow along the example from the JSON extension and use it for parquet.
import (
"context"
"database/sql"
"database/sql/driver"
"fmt"
"log"
"github.com/marcboeker/go-duckdb"
)
var db *sql.DB
func check(args ...interface{}) {
err := args[len(args)-1]
if err != nil {
panic(err)
}
}
func loadParquet(execer driver.ExecerContext) error {
bootQueries := []string{
"INSTALL 'parquet'",
"LOAD 'parquet'",
}
for _, qry := range bootQueries {
_, err := execer.ExecContext(context.TODO(), qry, nil)
if err != nil {
return err
}
}
return nil
}
type data struct {
c int64
}
func main() {
connector, err := duckdb.NewConnector("", loadParquet)
if err != nil {
fmt.Println("Failed to load Parquet")
log.Fatal(err)
}
db := sql.OpenDB(connector)
if err != nil {
log.Fatal(err)
}
defer db.Close()
check(db.Ping())
rows, err := db.Query(`select count(*) as c from read_parquet('my.parquet');`)
check(err)
defer rows.Close()
for rows.Next() {
c := new(data)
err := rows.Scan(&c.c)
if err != nil {
log.Fatal(err)
}
log.Printf("Count = %d", c.c)
fmt.Println(c.c)
}
}
from go-duckdb.
Related Issues (20)
- Is go-duckdb affected by duckdb/duckdb#10634? HOT 2
- NULL-bytes in BLOB HOT 1
- JSON (or any extension type) usage with Appender HOT 1
- Tables containing columns of type TIMESTAMPTZ cannot be queried. HOT 15
- install HOT 13
- Compilation error HOT 4
- Cannot pass schema and search_path as a DSN query param HOT 4
- Cannot create tables with Primary Key (silent fail) HOT 1
- How to manually commit the contents of the WAL file to the main database file before db closed? HOT 8
- [email protected]\appender.go:451:11: invalid array length 1 << 31 (untyped int constant 2147483648) HOT 2
- "unsupported type 17" on duckdb > 0.10.0 HOT 2
- Uncaught exception of type duckdb::InternalException HOT 1
- Add CI script to run gofumpt
- hope create a new tag for last update HOT 1
- Build failures on redhat linux HOT 1
- Support missing timestamp types in the appender HOT 1
- Detect incorrect column counts in the appender
- transaction.go:6:5: undefined: conn HOT 9
- Exposing filesystem interface HOT 1
- Make Apache Arrow Optional HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from go-duckdb.