Skip to content

Latest commit

 

History

History
61 lines (47 loc) · 1.41 KB

USAGE.md

File metadata and controls

61 lines (47 loc) · 1.41 KB

Use TiDB as Go library

When you use TiDB as Go library with a local storage engine, it works as an embedded database. One of the benefits of having an embedded database is that you can have a completely isolated environment to run tests. Removing the dependency of a real database for tests means you can run tests anywhere.

This is an example code to use TiDB as Go library.

package main

import (
	"database/sql"
	"fmt"

	_ "github.com/pingcap/tidb"
	"github.com/ngaut/log"

)

func main() {
	// Default log level is debug, set it to error to turn off debug log.
	log.SetLevelByString("error")

	// DriverName is 'tidb', dataSourceName is in the form of "<engine>://<dbPath>/<dbName>".
	// dbPath is the directory that stores the data files if you use a local storage engine.
	// dbName is the name of the database which you want to use.
	dbPath := "/tmp/tidb"
	dbName := "tidb"
	db, err := sql.Open("tidb", "goleveldb://" + dbPath + "/" + dbName)
	if err != nil {
		log.Fatal(err)
	}
	defer db.Close()

	_, err = db.Exec("CREATE TABLE IF NOT EXISTS t (a INT)")
	if err != nil {
		log.Fatal(err)
	}

	_, err = db.Exec("INSERT INTO t VALUES (?)", 1)
	if err != nil {
		log.Fatal(err)
	}

	row := db.QueryRow("SELECT * FROM t WHERE a = ?", 1)
	var val int
	err = row.Scan(&val)
	if err != nil {
		log.Fatal(err)
	}

	fmt.Printf("value is %d\n", val)

	_, err = db.Exec("DROP TABLE t")
	if err != nil {
		log.Fatal(err)
	}
}