执行查询sql时出错 - Golang

时间:2018-03-12 18:04:26

标签: sql database go sqlite

我尝试使用golang的本机sql apis在Golang中执行此查询。

type DB struct {
    *sql.DB
}

type IUser interface {
    CreateUserTable() (sql.Result, error)
}

//InitDB initializes the database
func InitDB() *DB {
    db, err := sql.Open(dbDriver, dbName)
    if err != nil {
        log.Fatal("failed to initialize database: ",err)
    }
    err2 := db.Ping()
    if err2 != nil {
        log.Fatal(err2)
    }

    // var database *DB
    // database.AutoMigrate(&domain.User{})

    return &DB{db}
}

func (db *DB) CreateUserTable() (sql.Result, error) {
    statement := "CREATE TABLE %s (%s, %s, %s, %s)"
    v := []interface{}{"User", "ID int PRIMARY KEY NOT NULL", "Name varchar(100) UNIQUE", "Email varchar(100) UNIQUE", "Address varchar(100) ",  "Username varchar(100) UNIQUE"}
    return db.Exec(fmt.Sprintf(statement, v...))
}

当我尝试在main函数中执行上面的操作时:

func main() {
    db := model.InitDB()
    newFunc(db)
}


func newFunc(db model.IUser) {
    r, err := db.CreateUserTable()
    if err != nil {
        fmt.Println("Error executing query - ", err)
    }
    fmt.Println(r)
}

它给了我错误:

  

执行查询时出错 - 接近"%":语法错误

如何解决这个问题? (我使用的是sqlite3驱动程序)

1 个答案:

答案 0 :(得分:0)

您的代码存在问题。在CREATE TABLE中缺少一个%s参数。

将代码更新为

  

声明:=“CREATE TABLE%s(%s,%s,%s,%s,%s)”