statement.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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. "errors"
  13. )
  14. type mysqlStmt struct {
  15. mc *mysqlConn
  16. id uint32
  17. paramCount int
  18. params []mysqlField
  19. }
  20. func (stmt *mysqlStmt) Close() (err error) {
  21. err = stmt.mc.writeCommandPacket(COM_STMT_CLOSE, stmt.id)
  22. stmt.mc = nil
  23. return
  24. }
  25. func (stmt *mysqlStmt) NumInput() int {
  26. return stmt.paramCount
  27. }
  28. func (stmt *mysqlStmt) Exec(args []driver.Value) (driver.Result, error) {
  29. if stmt.mc == nil {
  30. return nil, errors.New(`Invalid Statement`)
  31. }
  32. stmt.mc.affectedRows = 0
  33. stmt.mc.insertId = 0
  34. // Send command
  35. err := stmt.buildExecutePacket(args)
  36. if err != nil {
  37. return nil, err
  38. }
  39. // Read Result
  40. var resLen int
  41. resLen, err = stmt.mc.readResultSetHeaderPacket()
  42. if err != nil {
  43. return nil, err
  44. }
  45. if resLen > 0 {
  46. // Columns
  47. _, err = stmt.mc.readUntilEOF()
  48. if err != nil {
  49. return nil, err
  50. }
  51. // Rows
  52. stmt.mc.affectedRows, err = stmt.mc.readUntilEOF()
  53. if err != nil {
  54. return nil, err
  55. }
  56. }
  57. if err != nil {
  58. return nil, err
  59. }
  60. return &mysqlResult{
  61. affectedRows: int64(stmt.mc.affectedRows),
  62. insertId: int64(stmt.mc.insertId)},
  63. nil
  64. }
  65. func (stmt *mysqlStmt) Query(args []driver.Value) (driver.Rows, error) {
  66. if stmt.mc == nil {
  67. return nil, errors.New(`Invalid Statement`)
  68. }
  69. // Send command
  70. err := stmt.buildExecutePacket(args)
  71. if err != nil {
  72. return nil, err
  73. }
  74. // Read Result
  75. var resLen int
  76. resLen, err = stmt.mc.readResultSetHeaderPacket()
  77. if err != nil {
  78. return nil, err
  79. }
  80. rows := &mysqlRows{stmt.mc, true, nil, false}
  81. if resLen > 0 {
  82. // Columns
  83. rows.columns, err = stmt.mc.readColumns(resLen)
  84. if err != nil {
  85. return nil, err
  86. }
  87. }
  88. return rows, err
  89. }