statement.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // Go MySQL Driver - A MySQL-Driver for Go's database/sql package
  2. //
  3. // Copyright 2012 Julien Schmidt. All rights reserved.
  4. // http://www.julienschmidt.com
  5. //
  6. // This Source Code Form is subject to the terms of the Mozilla Public
  7. // License, v. 2.0. If a copy of the MPL was not distributed with this file,
  8. // You can obtain one at http://mozilla.org/MPL/2.0/.
  9. package mysql
  10. import (
  11. "database/sql/driver"
  12. )
  13. type mysqlStmt struct {
  14. mc *mysqlConn
  15. id uint32
  16. paramCount int
  17. params []mysqlField
  18. }
  19. func (stmt *mysqlStmt) Close() (err error) {
  20. if stmt.mc == nil || stmt.mc.netConn == nil {
  21. return errInvalidConn
  22. }
  23. err = stmt.mc.writeCommandPacketUint32(comStmtClose, stmt.id)
  24. stmt.mc = nil
  25. return
  26. }
  27. func (stmt *mysqlStmt) NumInput() int {
  28. return stmt.paramCount
  29. }
  30. func (stmt *mysqlStmt) Exec(args []driver.Value) (driver.Result, error) {
  31. stmt.mc.affectedRows = 0
  32. stmt.mc.insertId = 0
  33. // Send command
  34. err := stmt.writeExecutePacket(args)
  35. if err != nil {
  36. return nil, err
  37. }
  38. // Read Result
  39. var resLen int
  40. resLen, err = stmt.mc.readResultSetHeaderPacket()
  41. if err == nil {
  42. if resLen > 0 {
  43. // Columns
  44. err = stmt.mc.readUntilEOF()
  45. if err != nil {
  46. return nil, err
  47. }
  48. // Rows
  49. err = stmt.mc.readUntilEOF()
  50. }
  51. if err == nil {
  52. return &mysqlResult{
  53. affectedRows: int64(stmt.mc.affectedRows),
  54. insertId: int64(stmt.mc.insertId),
  55. }, nil
  56. }
  57. }
  58. return nil, err
  59. }
  60. func (stmt *mysqlStmt) Query(args []driver.Value) (driver.Rows, error) {
  61. // Send command
  62. err := stmt.writeExecutePacket(args)
  63. if err != nil {
  64. return nil, err
  65. }
  66. // Read Result
  67. var resLen int
  68. resLen, err = stmt.mc.readResultSetHeaderPacket()
  69. if err != nil {
  70. return nil, err
  71. }
  72. rows := &mysqlRows{stmt.mc, true, nil, false}
  73. if resLen > 0 {
  74. // Columns
  75. rows.columns, err = stmt.mc.readColumns(resLen)
  76. if err != nil {
  77. return nil, err
  78. }
  79. }
  80. return rows, err
  81. }