使用SQL数据库驱动程序

huangapple go评论150阅读模式
英文:

Using sql database driver

问题

请问一个终端用户(开发或生产)能否推荐一个最好使用“database/sql”包的Sql驱动程序包。我对Postgres、ODBC、MySql(可能还有其他一些,但不是Sqlite)感兴趣,最好能在Windows和/或Linux上使用(最好两者都可以)。对我来说,它可能需要最近更新/维护,并且必须与最新的Go版本配合使用。效率(吞吐量)显然很重要。欢迎提供任何相关评论。

英文:

Could an end-user (development or production) please recommend an Sql driver package that preferably uses the "database/sql" package. I'm interested in Postgres, ODBC, MySql (and possibly something else but for high-volume - ie. not Sqlite) that can preferably be used on Windows and/or Linux (preferably both). To be of interest to me it likely needs to have recently been updated /maintained and must work with latest Go release. Efficiency (throughput) is obviously important. Any relevant comments are welcome.

答案1

得分: 9

GO-SQL-Driver(MySQL):

> https://github.com/Go-SQL-Driver/MySQL

示例表格:

  1. CREATE TABLE `userinfo` (
  2. `uid` INT(10) NOT NULL AUTO_INCREMENT,
  3. `username` VARCHAR(64) NULL DEFAULT NULL,
  4. `departname` VARCHAR(64) NULL DEFAULT NULL,
  5. `created` DATE NULL DEFAULT NULL,
  6. PRIMARY KEY (`uid`)
  7. )
  8. CREATE TABLE `userdetail` (
  9. `uid` INT(10) NOT NULL DEFAULT '0',
  10. `intro` TEXT NULL,
  11. `profile` TEXT NULL,
  12. PRIMARY KEY (`uid`)
  13. )

示例代码:

  1. package main
  2. import (
  3. _ "github.com/Go-SQL-Driver/MySQL"
  4. "database/sql"
  5. "fmt"
  6. )
  7. func main() {
  8. db, err := sql.Open("mysql", "reckhou:reckhou@/test?charset=utf8")
  9. checkErr(err)
  10. //插入
  11. stmt, err := db.Prepare("INSERT userinfo SET username=?,departname=?,created=?")
  12. checkErr(err)
  13. res, err := stmt.Exec("reckhou", "IT", "2010-10-02")
  14. checkErr(err)
  15. id, err := res.LastInsertId()
  16. checkErr(err)
  17. fmt.Println(id)
  18. // 更新
  19. stmt, err = db.Prepare("update userinfo set username=? where uid=?")
  20. checkErr(err)
  21. res, err = stmt.Exec("update", id)
  22. checkErr(err)
  23. affect, err := res.RowsAffected()
  24. checkErr(err)
  25. fmt.Println(affect)
  26. //查询
  27. rows, err := db.Query("SELECT * FROM userinfo")
  28. checkErr(err)
  29. for rows.Next() {
  30. var uid int
  31. var username string
  32. var department string
  33. var created string
  34. err = rows.Scan(&uid, &username, &department, &created)
  35. checkErr(err)
  36. fmt.Println(uid)
  37. fmt.Println(username)
  38. fmt.Println(department)
  39. fmt.Println(created)
  40. }
  41. //删除
  42. stmt, err = db.Prepare("delete from userinfo where uid=?")
  43. checkErr(err)
  44. res, err = stmt.Exec(id)
  45. checkErr(err)
  46. affect, err = res.RowsAffected()
  47. checkErr(err)
  48. fmt.Println(affect)
  49. db.Close()
  50. }
  51. func checkErr(err error) {
  52. if err != nil {
  53. panic(err)
  54. }
  55. }

PostgreSQL:

> https://github.com/bmizerany/pq

示例表格:

  1. CREATE TABLE userinfo
  2. (
  3. uid serial NOT NULL,
  4. username character varying(100) NOT NULL,
  5. departname character varying(500) NOT NULL,
  6. Created date,
  7. CONSTRAINT userinfo_pkey PRIMARY KEY (uid)
  8. )
  9. WITH (OIDS=FALSE);
  10. CREATE TABLE userdeatail
  11. (
  12. uid integer,
  13. intro character varying(100),
  14. profile character varying(100)
  15. )
  16. WITH(OIDS=FALSE);

示例代码:

  1. import (
  2. "database/sql"
  3. "fmt"
  4. _ "github.com/bmizerany/pq"
  5. )
  6. func main() {
  7. db, err := sql.Open("postgres", "user=reckhou password=reckhou dbname=test sslmode=disable")
  8. checkErr(err)
  9. //插入
  10. stmt, err := db.Prepare("INSERT INTO userinfo(username,departname,created) VALUES($1,$2,$3) RETURNING uid")
  11. checkErr(err)
  12. res, err := stmt.Exec("reckhou", "IT", "2010-10-01")
  13. checkErr(err)
  14. id, err := res.LastInsertId()
  15. checkErr(err)
  16. fmt.Println(id)
  17. // 更新
  18. stmt, err = db.Prepare("update userinfo set username=$1 where uid=$2")
  19. checkErr(err)
  20. res, err = stmt.Exec("update", 1)
  21. checkErr(err)
  22. affect, err := res.RowsAffected()
  23. checkErr(err)
  24. fmt.Println(affect)
  25. // 查询
  26. rows, err := db.Query("SELECT * FROM userinfo")
  27. checkErr(err)
  28. for rows.Next() {
  29. var uid int
  30. var username string
  31. var department string
  32. var created string
  33. err = rows.Scan(&uid, &username, &department, &created)
  34. checkErr(err)
  35. fmt.Println(uid)
  36. fmt.Println(username)
  37. fmt.Println(department)
  38. fmt.Println(created)
  39. }
  40. // 删除
  41. stmt, err = db.Prepare("delete from userinfo where uid=$1")
  42. checkErr(err)
  43. res, err = stmt.Exec(1)
  44. checkErr(err)
  45. affect, err = res.RowsAffected()
  46. checkErr(err)
  47. fmt.Println(affect)
  48. db.Close()
  49. }
  50. func checkErr(err error) {
  51. if err != nil {
  52. panic(err)
  53. }
  54. }
英文:

GO-SQL-Driver(MySQL):

> https://github.com/Go-SQL-Driver/MySQL

Sample table:

  1. CREATE TABLE `userinfo` (
  2. `uid` INT(10) NOT NULL AUTO_INCREMENT,
  3. `username` VARCHAR(64) NULL DEFAULT NULL,
  4. `departname` VARCHAR(64) NULL DEFAULT NULL,
  5. `created` DATE NULL DEFAULT NULL,
  6. PRIMARY KEY (`uid`)
  7. )
  8. CREATE TABLE `userdetail` (
  9. `uid` INT(10) NOT NULL DEFAULT '0',
  10. `intro` TEXT NULL,
  11. `profile` TEXT NULL,
  12. PRIMARY KEY (`uid`)
  13. )

Sample code:

  1. package main
  2. import (
  3. _ "github.com/Go-SQL-Driver/MySQL"
  4. "database/sql"
  5. "fmt"
  6. )
  7. func main() {
  8. db, err := sql.Open("mysql", "reckhou:reckhou@/test?charset=utf8")
  9. checkErr(err)
  10. //Insert
  11. stmt, err := db.Prepare("INSERT userinfo SET username=?,departname=?,created=?")
  12. checkErr(err)
  13. res, err := stmt.Exec("reckhou", "IT", "2010-10-02")
  14. checkErr(err)
  15. id, err := res.LastInsertId()
  16. checkErr(err)
  17. fmt.Println(id)
  18. // Update
  19. stmt, err = db.Prepare("update userinfo set username=? where uid=?")
  20. checkErr(err)
  21. res, err = stmt.Exec("update", id)
  22. checkErr(err)
  23. affect, err := res.RowsAffected()
  24. checkErr(err)
  25. fmt.Println(affect)
  26. //Query
  27. rows, err := db.Query("SELECT * FROM userinfo")
  28. checkErr(err)
  29. for rows.Next() {
  30. var uid int
  31. var username string
  32. var department string
  33. var created string
  34. err = rows.Scan(&uid, &username, &department, &created)
  35. checkErr(err)
  36. fmt.Println(uid)
  37. fmt.Println(username)
  38. fmt.Println(department)
  39. fmt.Println(created)
  40. }
  41. //Delete
  42. stmt, err = db.Prepare("delete from userinfo where uid=?")
  43. checkErr(err)
  44. res, err = stmt.Exec(id)
  45. checkErr(err)
  46. affect, err = res.RowsAffected()
  47. checkErr(err)
  48. fmt.Println(affect)
  49. db.Close()
  50. }
  51. func checkErr(err error) {
  52. if err != nil {
  53. panic(err)
  54. }
  55. }

PostgreSQL:

> https://github.com/bmizerany/pq

Sample table:

  1. CREATE TABLE userinfo
  2. (
  3. uid serial NOT NULL,
  4. username character varying(100) NOT NULL,
  5. departname character varying(500) NOT NULL,
  6. Created date,
  7. CONSTRAINT userinfo_pkey PRIMARY KEY (uid)
  8. )
  9. WITH (OIDS=FALSE);
  10. CREATE TABLE userdeatail
  11. (
  12. uid integer,
  13. intro character varying(100),
  14. profile character varying(100)
  15. )
  16. WITH(OIDS=FALSE);

Sample code:

  1. import (
  2. "database/sql"
  3. "fmt"
  4. _ "github.com/bmizerany/pq"
  5. )
  6. func main() {
  7. db, err := sql.Open("postgres", "user=reckhou password=reckhou dbname=test sslmode=disable")
  8. checkErr(err)
  9. //Insert
  10. stmt, err := db.Prepare("INSERT INTO userinfo(username,departname,created) VALUES($1,$2,$3) RETURNING uid")
  11. checkErr(err)
  12. res, err := stmt.Exec("reckhou", "IT", "2010-10-01")
  13. checkErr(err)
  14. id, err := res.LastInsertId()
  15. checkErr(err)
  16. fmt.Println(id)
  17. // Update
  18. stmt, err = db.Prepare("update userinfo set username=$1 where uid=$2")
  19. checkErr(err)
  20. res, err = stmt.Exec("update", 1)
  21. checkErr(err)
  22. affect, err := res.RowsAffected()
  23. checkErr(err)
  24. fmt.Println(affect)
  25. // Query
  26. rows, err := db.Query("SELECT * FROM userinfo")
  27. checkErr(err)
  28. for rows.Next() {
  29. var uid int
  30. var username string
  31. var department string
  32. var created string
  33. err = rows.Scan(&uid, &username, &department, &created)
  34. checkErr(err)
  35. fmt.Println(uid)
  36. fmt.Println(username)
  37. fmt.Println(department)
  38. fmt.Println(created)
  39. }
  40. // Delete
  41. stmt, err = db.Prepare("delete from userinfo where uid=$1")
  42. checkErr(err)
  43. res, err = stmt.Exec(1)
  44. checkErr(err)
  45. affect, err = res.RowsAffected()
  46. checkErr(err)
  47. fmt.Println(affect)
  48. db.Close()
  49. }
  50. func checkErr(err error) {
  51. if err != nil {
  52. panic(err)
  53. }
  54. }

huangapple
  • 本文由 发表于 2013年4月17日 15:42:46
  • 转载请务必保留本文链接:https://go.coder-hub.com/16054317.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定