我试图使用Dapper扩展来执行CRUD操作。但是,我在将数据插入MySQL数据库时出错,如下所示:
错误:您的SQL语法有错误;请检查与您的MySQL服务器版本相对应的手册,以获得正确的语法.在排队..。
如果我使用MSSQL数据库,Dapper扩展将正常工作。为什么我要从MySQL中得到这个错误?
发布于 2018-10-27 06:21:17
这个错误是因为Dapper扩展正在为server生成查询(默认情况下),因为您实际上是连接到MySQL的。这两个RDBMS之间存在语法差异,因此出现了错误。您必须告诉Dapper扩展插件您正在连接到MySQL。
在应用程序启动时,在某个地方设置方言。
//Synchronous
DapperExtensions.DapperExtensions.SqlDialect = new DapperExtensions.Sql.MySqlDialect();
//Asynchronous
DapperExtensions.DapperAsyncExtensions.SqlDialect = new DapperExtensions.Sql.MySqlDialect();正如您可以注意到的,您需要分别为同步和异步方法配置这一点。您可以在github上读到更多关于这方面的内容。
这将指示Dapper扩展根据MySql的语法生成查询。不仅是Dapper扩展,对于许多ORM来说,类似的扩展也是必需的--它们支持为多个RDBMS生成查询。
除此之外,您还可以考虑实现日志记录,这可能会帮助您诊断问题。MiniProfiler是实现这一目的的好工具。您可以在我的其他回答中找到更多的细节。
https://stackoverflow.com/questions/53016610
复制相似问题