目前我正在尝试在datebase中插入日期时间值。但错误:
“附加信息:'/'附近语法不正确。”
不断出现。
这是我的代码:
SqlConnection conn = SqlConn.openSqlConnection();
conn.Open();
SqlCommand comm = new SqlCommand("makeRit", conn);
comm.CommandType = System.Data.CommandType.StoredProcedure;
checkRitNr();
comm.Parameters.AddWithValue("@username", username);
comm.Parameters.AddWithValue("@Nr",ritnr);
comm.Parameters.AddWithValue("@Datum", ritValue[0]);
comm.Parameters.AddWithValue("@Beginstand", ritValue[1]);
comm.Parameters.AddWithValue("@Eindstand", ritValue[2]);
comm.Parameters.AddWithValue("@Van", ritValue[3]);
comm.Parameters.AddWithValue("@Naar", ritValue[4]);
comm.Parameters.AddWithValue("@Bezoekadres", ritValue[5]);
comm.Parameters.AddWithValue("@Geredenroute", ritValue[6]);
comm.Parameters.AddWithValue("@Karakterrit", ritValue[7]);
comm.Parameters.AddWithValue("@Toelichting", ritValue[8]);
comm.Parameters.AddWithValue("@Kilometerszakelijk", ritValue[9]);
comm.Parameters.AddWithValue("@Kilometersprive", ritValue[10]);
comm.Parameters.AddWithValue("@date", DateTime.Today);
added = comm.ExecuteNonQuery();
conn.Close();
这是存储过程:
@username varchar(50),
@Nr int,
@Datum varchar(50),
@Beginstand varchar(50),
@Eindstand varchar(50),
@Van varchar(50),
@Naar varchar(50),
@Bezoekadres varchar(50),
@Geredenroute varchar(50),
@karakterrit varchar(50),
@Toelichting varchar(50),
@kilometerszakelijk varchar(50),
@kilometersprive varchar(50),
@date datetime
as
begin
Exec ('insert into'+@username+'ritteninformatie'+'values('+@Nr+','+@Datum+','+@Beginstand+','+@Eindstand+','+@Van+','+@Naar+','+@Bezoekadres+','+@Geredenroute+','+@Karakterrit+','+@Toelichting+','+@Kilometerszakelijk+','+@Kilometersprive+','+@date)
end
我正在尝试在具有“datetime”值的“date”中插入今天的日期。我要将它作为日期时间而不是字符串插入。
答案 0 :(得分:3)
直接使用sp_executeSQL
代替EXEC
,并将您的变量作为参数传递给sp_executeSQL
,如下所示。
DECLARE @sql NVARCHAR(MAX) = 'insert into '+@username+'ritteninformatie'+' values(
@Nr,@Datum,@Beginstand,@Eindstand,@Van,@Naar,@Bezoekadres,@Geredenroute,@Karakterrit,@Toelichting,@Kilometerszakelijk,@Kilometersprive,@date)'
EXEC sp_executeSQL @sql,N'@Nr int,
@Datum varchar(50),
@Beginstand varchar(50),
@Eindstand varchar(50),
@Van varchar(50),
@Naar varchar(50),
@Bezoekadres varchar(50),
@Geredenroute varchar(50),
@karakterrit varchar(50),
@Toelichting varchar(50),
@kilometerszakelijk varchar(50),
@kilometersprive varchar(50),
@date datetime',@Nr,@Datum,@Beginstand,@Eindstand,@Van,@Naar,@Bezoekadres,@Geredenroute,@Karakterrit,@Toelichting,@Kilometerszakelijk,@Kilometersprive,@date