0

我正在尝试使用 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 会有所帮助。

4

1 回答 1

0

所以发生的事情正是@KirkWoll 所说的,我公司的 dll 里面有 dapper 的 dll,所以我只是删除了我项目的 dapper 引用,一切正常。

于 2013-04-03T18:18:14.600 回答