我正在尝试使用 Dapper 对 SQLite 数据库执行简单的 CRUD 操作,但我遇到了麻烦,因为编译器正在指责一个我根本不知道如何修复的错误。
问题中的错误在“conn.Execute ...”行中,它说:
C#:有几种方法适用于 '(string, DBManager.(anonymous))': 'Dapper.SqlMapper.Execute(System.Data.IDbConnection, string, , System.Data.IDbTransaction, int?, System.Data.CommandType? )' 和 'Dapper.SqlMapper.Execute(System.Data.IDbConnection, string, , System.Data.IDbTransaction, int?, System.Data.CommandType?)' DBManager.cs
下面是我的代码,我试着把我认为有用的所有东西都放在这里,但不要放太多。
using System;
using System.Linq;
using Dapper;
public bool Insert(SchedulerHistory record)
{
int res = -1;
if (record == null)
return false;
try
{
//var db = new SQLDatabase();
string sqlquery = "insert into SchedulerHistory (JobId, NextJob, LastJob, ExecuteOnStart) Values (@JobId, @NextJob, @LastJob, @ExecuteOnStart);";
using (var conn = new System.Data.SQLite.SQLiteConnection(m_connString))
{
conn.Open();
conn.Execute (sqlquery, new { JobId = record.JobId, NextJob = `record.NextJob, LastJob = record.LastJob, ExecuteOnStart = record.ExecuteOnStart });`
return (res > 0);
}
}
catch (Exception ex)
{
LogWriter.Error(ex);
return false;
}
}
注意“使用 Dapper;” 被 VS2012 标记为未使用,并且该方法尚未完成,我正在根据我之前所做的进行调整,因为我认为 dapper 会有所帮助。