首页 >后端开发 >Golang >尽管日志中的输出相同,为什么 Sqlmock 无法匹配我的查询?

尽管日志中的输出相同,为什么 Sqlmock 无法匹配我的查询?

Linda Hamilton
Linda Hamilton原创
2024-11-12 16:59:02264浏览

Why is Sqlmock Failing to Match My Query Despite Identical Output in the Log?

尽管日志输出中有身份,Sqlmock 仍不匹配查询

错误消息

尝试使用 sqlmock 匹配 Gorm 测试中的查询时,出现以下情况遇到错误:

(path/to/my/project/database.go:263)
[2020-01-08 10:29:40]  Query: could not match actual sql: "SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1" with expected regexp "SELECT * FROM "storage_pools" WHERE "storage_pools"."deleted_at" IS NULL AND ((poolid = ?)) ORDER BY "storage_pools"."id" ASC LIMIT 1"

解决方案

问题源于使用 regexp 作为 sqlmock 查询匹配器。默认情况下,sqlmock 使用严格相等查询匹配器,这要求实际查询与预期模式之间完全匹配。

要解决此问题,请使用 QueryMatcherEqual 选项替换默认查询匹配器:

QueryMatcherOption(sqlmock.QueryMatcherEqual)

其他注意事项

  • 确保 sqlmock 查询与实际查询字符串匹配,包括可能需要转义的任何特殊字符。
  • 如果查询包含文字值,使用 WithArgs() 指定参数并根据需要转义它们。
  • 如果查询包含函数或复杂条件,请使用 regexp.QuoteMeta() 将其转换为 sqlmock 可以匹配的正则表达式。

以上是尽管日志中的输出相同,为什么 Sqlmock 无法匹配我的查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn