statement.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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. columns []mysqlField // cached from the first query
  17. }
  18. func (stmt *mysqlStmt) Close() error {
  19. if stmt.mc == nil || stmt.mc.netConn == nil {
  20. return errInvalidConn
  21. }
  22. err := stmt.mc.writeCommandPacketUint32(comStmtClose, stmt.id)
  23. stmt.mc = nil
  24. return err
  25. }
  26. func (stmt *mysqlStmt) NumInput() int {
  27. return stmt.paramCount
  28. }
  29. func (stmt *mysqlStmt) Exec(args []driver.Value) (driver.Result, error) {
  30. if stmt.mc.netConn == nil {
  31. return nil, errInvalidConn
  32. }
  33. // Send command
  34. err := stmt.writeExecutePacket(args)
  35. if err != nil {
  36. return nil, err
  37. }
  38. mc := stmt.mc
  39. mc.affectedRows = 0
  40. mc.insertId = 0
  41. // Read Result
  42. resLen, err := mc.readResultSetHeaderPacket()
  43. if err == nil {
  44. if resLen > 0 {
  45. // Columns
  46. err = mc.readUntilEOF()
  47. if err != nil {
  48. return nil, err
  49. }
  50. // Rows
  51. err = mc.readUntilEOF()
  52. }
  53. if err == nil {
  54. return &mysqlResult{
  55. affectedRows: int64(mc.affectedRows),
  56. insertId: int64(mc.insertId),
  57. }, nil
  58. }
  59. }
  60. return nil, err
  61. }
  62. func (stmt *mysqlStmt) Query(args []driver.Value) (driver.Rows, error) {
  63. if stmt.mc.netConn == nil {
  64. return nil, errInvalidConn
  65. }
  66. // Send command
  67. err := stmt.writeExecutePacket(args)
  68. if err != nil {
  69. return nil, err
  70. }
  71. mc := stmt.mc
  72. // Read Result
  73. resLen, err := mc.readResultSetHeaderPacket()
  74. if err != nil {
  75. return nil, err
  76. }
  77. rows := &mysqlRows{mc, nil, true, false}
  78. if resLen > 0 {
  79. // Columns
  80. // If not cached, read them and cache them
  81. if stmt.columns == nil {
  82. rows.columns, err = mc.readColumns(resLen)
  83. stmt.columns = rows.columns
  84. } else {
  85. rows.columns = stmt.columns
  86. err = mc.readUntilEOF()
  87. }
  88. }
  89. return rows, err
  90. }