statement.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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. err = stmt.mc.writeCommandPacketUint32(COM_STMT_CLOSE, stmt.id)
  21. stmt.mc = nil
  22. return
  23. }
  24. func (stmt *mysqlStmt) NumInput() int {
  25. return stmt.paramCount
  26. }
  27. func (stmt *mysqlStmt) Exec(args []driver.Value) (driver.Result, error) {
  28. stmt.mc.affectedRows = 0
  29. stmt.mc.insertId = 0
  30. // Send command
  31. err := stmt.writeExecutePacket(args)
  32. if err != nil {
  33. return nil, err
  34. }
  35. // Read Result
  36. var resLen int
  37. resLen, err = stmt.mc.readResultSetHeaderPacket()
  38. if err != nil {
  39. return nil, err
  40. }
  41. if resLen > 0 {
  42. // Columns
  43. _, err = stmt.mc.readUntilEOF()
  44. if err != nil {
  45. return nil, err
  46. }
  47. // Rows
  48. stmt.mc.affectedRows, err = stmt.mc.readUntilEOF()
  49. if err != nil {
  50. return nil, err
  51. }
  52. }
  53. if err != nil {
  54. return nil, err
  55. }
  56. return &mysqlResult{
  57. affectedRows: int64(stmt.mc.affectedRows),
  58. insertId: int64(stmt.mc.insertId),
  59. }, nil
  60. }
  61. func (stmt *mysqlStmt) Query(args []driver.Value) (driver.Rows, error) {
  62. // Send command
  63. err := stmt.writeExecutePacket(args)
  64. if err != nil {
  65. return nil, err
  66. }
  67. // Read Result
  68. var resLen int
  69. resLen, err = stmt.mc.readResultSetHeaderPacket()
  70. if err != nil {
  71. return nil, err
  72. }
  73. rows := &mysqlRows{stmt.mc, true, nil, false}
  74. if resLen > 0 {
  75. // Columns
  76. rows.columns, err = stmt.mc.readColumns(resLen)
  77. if err != nil {
  78. return nil, err
  79. }
  80. }
  81. return rows, err
  82. }