main.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package main
  2. import (
  3. "database/sql"
  4. "log"
  5. _ "xugu_go_driver/xugu"
  6. )
  7. func main() {
  8. db, err := sql.Open("xugusql", "IP=10.28.20.101;DB=SYSTEM;User=SYSDBA;PWD=SYSDBA;Port=5190;AUTO_COMMIT=on;CHAR_SET=UTF8")
  9. if err != nil {
  10. log.Fatal("err ", err)
  11. }
  12. // if err := db.Ping(); err != nil {
  13. // log.Fatal("err ping ", err)
  14. // }
  15. // rows, err := db.Query("select * from dual")
  16. // if err != nil {
  17. // log.Fatal(err)
  18. // }
  19. // // rows, err := db.Query("select * from test1 where id = ?;", 4)
  20. // // if err != nil {
  21. // // log.Fatal(err)
  22. // // }
  23. // var cols []string
  24. // cols, err = rows.Columns()
  25. // if err != nil {
  26. // log.Fatal(err)
  27. // }
  28. // fmt.Println("cols: ", cols)
  29. // pvals := make([]interface{}, len(cols))
  30. // for key, _ := range pvals {
  31. // dest := make([]byte, 216)
  32. // pvals[key] = &dest
  33. // } /* end for */
  34. // for rows.Next() {
  35. // err = rows.Scan(pvals...)
  36. // if err != nil {
  37. // log.Fatal(err)
  38. // }
  39. // for _, v := range pvals {
  40. // fmt.Printf("输出 %s\t", string(*(v.(*[]byte))))
  41. // }
  42. // fmt.Printf("\n")
  43. // }
  44. // rows.Close()
  45. // stmt, err := db.Prepare("select * from test1 where id = ?")
  46. // if err != nil {
  47. // log.Fatal(err)
  48. // }
  49. // stmt.Exec(2)
  50. // ret, err := db.Exec("insert into test1 (id) values (9)")
  51. // if err != nil {
  52. // log.Fatal(err)
  53. // }
  54. // ret.LastInsertId()
  55. // stmt, err := db.Prepare("select * from test1 where id = ?")
  56. // if err != nil {
  57. // log.Fatal(err)
  58. // }
  59. // rows, err := stmt.Query(5)
  60. // if err != nil {
  61. // log.Fatal(err)
  62. // }
  63. // var cols []string
  64. // cols, err = rows.Columns()
  65. // if err != nil {
  66. // log.Fatal(err)
  67. // }
  68. // fmt.Println("cols: ", cols)
  69. // pvals := make([]interface{}, len(cols))
  70. // for key, _ := range pvals {
  71. // dest := make([]byte, 216)
  72. // pvals[key] = &dest
  73. // } /* end for */
  74. // for rows.Next() {
  75. // err = rows.Scan(pvals...)
  76. // if err != nil {
  77. // log.Fatal(err)
  78. // }
  79. // for _, v := range pvals {
  80. // fmt.Printf("输出 %s\t", string(*(v.(*[]byte))))
  81. // }
  82. // fmt.Printf("\n")
  83. // }
  84. // rows.Close()
  85. db.Exec("set auto_commit on;")
  86. }