使用 Dapper 将 byte[] 数组转换为 sqldbtype.Varbinary

Lon*_*dow 4 c# sql sql-server entity-framework dapper

我在互联网上找到了一段代码,该代码将文档作为字节数组插入数据库中。如下:

    public void databaseFilePut(string varFilePath)
    {
        byte[] file;
        using (var stream = new FileStream(varFilePath, FileMode.Open, FileAccess.Read))
        {
            using (var reader = new BinaryReader(stream))
            {
                file = reader.ReadBytes((int)stream.Length);
            }
        }

        //using (var varConnection = Locale.sqlConnectOneTime(Locale.slqDataConnectionDetails))
        using (SqlConnection connection = new SqlConnection(connectionString))
        using (var sqlWrite = new SqlCommand("INSERT INTO EXCEL_EM_BYTES (DOCUMENTO_BYTES) Values(@File)", connection))
        {
            sqlWrite.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;
            connection.Open();
            sqlWrite.ExecuteNonQuery();
            connection.Close();
        }
    }
Run Code Online (Sandbox Code Playgroud)

现在,我必须将其应用到 Dapper/Entity 框架,但到目前为止,还没有成功。到目前为止我得到的信息如下:

      public void InsereRegistroEmail(string a, string b, string c, byte[] anexoBytes)
    {
        //var cn = _context.Database.Connection;

        //cn.Execute(string.Format(QueriesSAC.InsereRegistroEmailBanco, motivoEmail, nomeGestor, corpoEmail, anexoBytes));

        var cn = _context.Database.Connection;
        //var A = new SqlParameter("@A", SqlDbType.VarBinary, anexoBytes.Length);
        //A.Value = anexoBytes;

        var sql =(string.Format("INSERT INTO [LOG_EMAIL] ([GSTOR_DSTNA] ,[ASSNT],[DATA_ENVIO],[CORPO_EMAIL],[ANEXO]) VALUES('{0}','{1}', GETDATE(),'{2}', @A)", a, b, c));
        var A = new DynamicParameters();
        A.Add("@A", anexoBytes, dbType: DbType.Binary, direction: ParameterDirection.Input);
        A.Get<DbType>("@A");
        cn.Execute(sql);
    }
Run Code Online (Sandbox Code Playgroud)

这里的关键是:

         sqlWrite.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;
Run Code Online (Sandbox Code Playgroud)

将数据类型设置为 VarBinary 的也是如此。我真的需要一些帮助......

文件数组是anexoBytes。

G D*_*son 5

Dapper 可以通过匿名类型来代替参数值来处理分配,因此在您的示例中,您只需更改 SQL 来定义一些参数化 SQL,然后传入包含这些参数值的新对象。这将自动将值映射到其参数,并避免需要手动定义它们或对 SQL 执行字符串替换。

_connection.Execute("INSERT INTO [LOG_EMAIL] ([GSTOR_DSTNA] ,[ASSNT],[DATA_ENVIO],[CORPO_EMAIL],[ANEXO]) VALUES(@DstNa, @Assnt, GETDATE(), @CorpEmail, @Anexo",
            new { DstNa = a, Assnt = b, CorpEmail = c, Anexo = anexoBytes });
Run Code Online (Sandbox Code Playgroud)