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

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

Linda Hamilton
发布: 2024-11-12 16:59:02
原创
270 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板