我有一个mysql语句传递给dapper查询方法,它返回一个空对象。我已经创建了一个POCO类来保存返回的结果。我直接通过一个sql编辑器测试了这个查询,它返回了一个结果。代码如下:
public ViewEmail GetViewEmail(string xId, int headerId)
{
using (IDbConnection connection = new MySqlConnection(_connectionString))
{
string sql = "SELECT * FROM ViewEmail " +
"WHERE Header_id = @Header_id " +
"AND x_id= '@x_id'";
var viewEmail = connection
.Query<ViewEmail>(sql, new { Header_id = HeaderId, x_id = xId })
.SingleOrDefault();
return viewEmail;
}
}
最佳答案
使用准备好的语句时,不需要用'
包装参数。请改为:
string sql = "SELECT * FROM ViewEmail " +
"WHERE Header_id = @Header_id " +
"AND x_id= @x_id";
见Documentation
关于c# - 为什么此精简查询返回null?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28946889/