C#编程,输入为空时,报错:异常详细信息: System.FormatException: 该字符串未被识别为有效的 DateTime
请看代码:sqlStr="insertinto[XSB](CSSJ,ZXF)values(@CSSJ,@ZXF)";SqlCommandcmd=newSqlCommand...
请看代码:
sqlStr = "insert into[XSB](CSSJ,ZXF)values(@CSSJ,@ZXF)";
SqlCommand cmd=new SqlCommand(sqlStr,conn);
cmd.Parameters.Add("@CSSJ", SqlDbType.Date).Value = StuCSSJ.Text.Trim();
cmd.Parameters.Add("@ZXF", SqlDbType.Int).Value = StuZXF.Text.Trim();
大神求助啊,只要没有输出内容,这两项插入就都要报错,我想实现的是不输入就不做改动嘛 展开
sqlStr = "insert into[XSB](CSSJ,ZXF)values(@CSSJ,@ZXF)";
SqlCommand cmd=new SqlCommand(sqlStr,conn);
cmd.Parameters.Add("@CSSJ", SqlDbType.Date).Value = StuCSSJ.Text.Trim();
cmd.Parameters.Add("@ZXF", SqlDbType.Int).Value = StuZXF.Text.Trim();
大神求助啊,只要没有输出内容,这两项插入就都要报错,我想实现的是不输入就不做改动嘛 展开
展开全部
语句也有问题
string cssj=StuCSSJ.Text.Trim();
string zxf=StuZXF.Text.Trim();
if(cssj!="" && zxf!="")
{
sqlStr = "insert into [XSB](CSSJ,ZXF) values (@CSSJ,@ZXF)";
SqlCommand cmd=new SqlCommand(sqlStr,conn);
cmd.Parameters.Add("@CSSJ", SqlDbType.Date).Value = cssj;
cmd.Parameters.Add("@ZXF", SqlDbType.Int).Value =zxf;
//执行
}
string cssj=StuCSSJ.Text.Trim();
string zxf=StuZXF.Text.Trim();
if(cssj!="" && zxf!="")
{
sqlStr = "insert into [XSB](CSSJ,ZXF) values (@CSSJ,@ZXF)";
SqlCommand cmd=new SqlCommand(sqlStr,conn);
cmd.Parameters.Add("@CSSJ", SqlDbType.Date).Value = cssj;
cmd.Parameters.Add("@ZXF", SqlDbType.Int).Value =zxf;
//执行
}
追问
你这个就必须都不为空才能执行插入操作,能不能让哪个有值就插入哪个,没有值就不插入呢?我的整个程序是增加学生信息,学号,姓名,出生时间,总学分这些,希望能做到有值就插入,没有值就空着,请问怎么实现呢?
追答
原理基本一样
string cssj=StuCSSJ.Text.Trim();
string zxf=StuZXF.Text.Trim();
sqlStr = "insert into [XSB]({0}) values ({1})";
string fields="";
string valist="";
List list=new List();
if(cssj=="")
{
fields+="cssj,";
valist+="@cssj,";
SqlParameter par = new SqlParameter("@cssj", SqlDbType.Date);
par.Value =DateTime.Parse(cssj);//你原本的赋值按你指定的类型是错的,下面也是一样,不太清楚具体情况,你自己修改一下
list.Add(par);
}
if(zxf!="")
{
fields+="zxf,";
valist+="@zxf,";
SqlParameter par = new SqlParameter("@zxf", SqlDbType.int);
par.Value =int.Parse(zxf);
list.Add(par);
}
fields=fields.Trim(',');
valist=valist.Trim(',');
if(list.Count>0)
{
sqlStr=string.Format(sqlStr,fields,valist);
SqlCommand cmd=new SqlCommand(sqlStr,conn);
cmd.AddRange(list);//或者是cmd.AddRange(list.ToArray());
//执行
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询