在数据库中插入datetime时出错

时间:2015-05-06 12:50:42

标签: c# sql datetime

目前我正在尝试在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”中插入今天的日期。我要将它作为日期时间而不是字符串插入。

1 个答案:

答案 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