errors.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. // Go MySQL Driver - A MySQL-Driver for Go's database/sql package
  2. //
  3. // Copyright 2013 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. "errors"
  12. "fmt"
  13. "io"
  14. "log"
  15. "os"
  16. "sync"
  17. )
  18. var (
  19. errInvalidConn = errors.New("Invalid Connection")
  20. errMalformPkt = errors.New("Malformed Packet")
  21. errNoTLS = errors.New("TLS encryption requested but server does not support TLS")
  22. errOldPassword = errors.New("This server only supports the insecure old password authentication. If you still want to use it, please add 'allowOldPasswords=1' to your DSN. See also https://github.com/go-sql-driver/mysql/wiki/old_passwords")
  23. errOldProtocol = errors.New("MySQL-Server does not support required Protocol 41+")
  24. errPktSync = errors.New("Commands out of sync. You can't run this command now")
  25. errPktSyncMul = errors.New("Commands out of sync. Did you run multiple statements at once?")
  26. errPktTooLarge = errors.New("Packet for query is too large. You can change this value on the server by adjusting the 'max_allowed_packet' variable.")
  27. errBusyBuffer = errors.New("Busy buffer")
  28. errNoLogger = errors.New("logger is nil")
  29. errLog Logger = log.New(os.Stderr, "[MySQL] ", log.Ldate|log.Ltime|log.Lshortfile)
  30. errLogLock = &sync.Mutex{}
  31. )
  32. // Logger is used to log critical error messages.
  33. type Logger interface {
  34. Print(v ...interface{})
  35. }
  36. // SetLogger is used to set the logger for critical errors.
  37. // The initial logger is stderr.
  38. func SetLogger(logger Logger) error {
  39. if logger == nil {
  40. return errNoLogger
  41. }
  42. errLogLock.Lock()
  43. errLog = logger
  44. errLogLock.Unlock()
  45. return nil
  46. }
  47. // MySQLError is an error type which represents a single MySQL error
  48. type MySQLError struct {
  49. Number uint16
  50. Message string
  51. }
  52. func (me *MySQLError) Error() string {
  53. return fmt.Sprintf("Error %d: %s", me.Number, me.Message)
  54. }
  55. // MySQLWarnings is an error type which represents a group of one or more MySQL
  56. // warnings
  57. type MySQLWarnings []MysqlWarning
  58. func (mws MySQLWarnings) Error() string {
  59. var msg string
  60. for i, warning := range mws {
  61. if i > 0 {
  62. msg += "\r\n"
  63. }
  64. msg += fmt.Sprintf(
  65. "%s %s: %s",
  66. warning.Level,
  67. warning.Code,
  68. warning.Message,
  69. )
  70. }
  71. return msg
  72. }
  73. // MysqlWarning is an error type which represents a single MySQL warning.
  74. // Warnings are returned in groups only. See MySQLWarnings
  75. type MysqlWarning struct {
  76. Level string
  77. Code string
  78. Message string
  79. }
  80. func (mc *mysqlConn) getWarnings() (err error) {
  81. rows, err := mc.Query("SHOW WARNINGS", []driver.Value{})
  82. if err != nil {
  83. return
  84. }
  85. var warnings = MySQLWarnings{}
  86. var values = make([]driver.Value, 3)
  87. var warning MysqlWarning
  88. var raw []byte
  89. var ok bool
  90. for {
  91. err = rows.Next(values)
  92. switch err {
  93. case nil:
  94. warning = MysqlWarning{}
  95. if raw, ok = values[0].([]byte); ok {
  96. warning.Level = string(raw)
  97. } else {
  98. warning.Level = fmt.Sprintf("%s", values[0])
  99. }
  100. if raw, ok = values[1].([]byte); ok {
  101. warning.Code = string(raw)
  102. } else {
  103. warning.Code = fmt.Sprintf("%s", values[1])
  104. }
  105. if raw, ok = values[2].([]byte); ok {
  106. warning.Message = string(raw)
  107. } else {
  108. warning.Message = fmt.Sprintf("%s", values[0])
  109. }
  110. warnings = append(warnings, warning)
  111. case io.EOF:
  112. return warnings
  113. default:
  114. rows.Close()
  115. return
  116. }
  117. }
  118. }