statement.go 1.8 KB

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