我正在尝试将值插入到包含varbinary(MAX)的表中,我尝试插入的文件是byte []
public DataTable add1(string docName , byte[] doc)
{
DBAdaptor db = new DBAdaptor();
string query = "INSERT INTO [Document] (DocumentName, DocumentData) OUTPUT inserted.DocumentID VALUES (N'" + docName + "' , " + doc + ")";
return db.QueryRide(query);
}
我得到了这个例外:
对象或列名称缺失或为空。对于SELECT INTO 声明,验证每列是否有名称。对于其他陈述,请查看 对于空别名。不允许使用定义为“”或[]的别名。 将别名更改为有效名称。
''。
附近的语法不正确
这是执行我的查询的函数:
public DataTable QueryRide(string query)
{
DataTable dt = new DataTable();
string conStr = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
SqlConnection con = new SqlConnection(conStr);
SqlCommand cmd = new SqlCommand(query, con);
SqlDataAdapter da = new SqlDataAdapter(cmd);
try
{
con.Open();
da.Fill(dt);
}
catch (Exception)
{
throw;
}
finally
{
if (con.State == ConnectionState.Open)
con.Close();
}
return dt;
}
如何将此字节[]插入到我的表中?感谢
答案 0 :(得分:3)
试试这个:
private static int insertDocument(string name, byte[] data)
{
using (SqlConnection cn = new SqlConnection("..."))
using (SqlCommand cm = cn.CreateCommand())
{
cm.CommandText = @"
INSERT INTO [Document] (DocumentName, DocumentData)
OUTPUT inserted.DocumentID
VALUES (@Name, @Data)";
cm.Parameters.AddWithValue("@Name", name);
cm.Parameters.AddWithValue("@Data", data);
cn.Open();
return (int)cm.ExecuteScalar();
}
}