//go:build (linux || darwin || windows) && sqlite // +build linux darwin windows // +build sqlite // limited GOOS due to modernc.org/libc/unistd package sqlite import ( "context" "database/sql" "fmt" "github.com/seaweedfs/seaweedfs/weed/filer" "github.com/seaweedfs/seaweedfs/weed/filer/abstract_sql" "github.com/seaweedfs/seaweedfs/weed/filer/mysql" "github.com/seaweedfs/seaweedfs/weed/util" _ "modernc.org/sqlite" ) func init() { filer.Stores = append(filer.Stores, &SqliteStore{}) } type SqliteStore struct { abstract_sql.AbstractSqlStore } func (store *SqliteStore) GetName() string { return "sqlite" } func (store *SqliteStore) Initialize(configuration util.Configuration, prefix string) (err error) { dbFile := configuration.GetString(prefix + "dbFile") createTable := `CREATE TABLE IF NOT EXISTS "%s" ( dirhash BIGINT, name VARCHAR(1000), directory TEXT, meta BLOB, PRIMARY KEY (dirhash, name) ) WITHOUT ROWID;` upsertQuery := `INSERT INTO "%s"(dirhash,name,directory,meta)VALUES(?,?,?,?) ON CONFLICT(dirhash,name) DO UPDATE SET directory=excluded.directory, meta=excluded.meta; ` return store.initialize( dbFile, createTable, upsertQuery, ) } func (store *SqliteStore) initialize(dbFile, createTable, upsertQuery string) (err error) { store.SupportBucketTable = true store.SqlGenerator = &mysql.SqlGenMysql{ CreateTableSqlTemplate: createTable, DropTableSqlTemplate: "drop table `%s`", UpsertQueryTemplate: upsertQuery, } var dbErr error store.DB, dbErr = sql.Open("sqlite", "file:"+dbFile) if dbErr != nil { if store.DB != nil { store.DB.Close() store.DB = nil } return fmt.Errorf("can not connect to %s error:%v", dbFile, dbErr) } if err = store.DB.Ping(); err != nil { return fmt.Errorf("connect to %s error:%v", dbFile, err) } store.DB.SetMaxOpenConns(1) if err = store.CreateTable(context.Background(), abstract_sql.DEFAULT_TABLE); err != nil { return fmt.Errorf("init table %s: %v", abstract_sql.DEFAULT_TABLE, err) } return nil }