C#中将Label中的值利用SQL语句写到数据库中
a=float.Parse(label1.Text);stringstr="updatetable(这是表名)setTot=Tot+awhereCard='"+textB...
a = float.Parse(label1.Text);
string str= "update table(这是表名) set Tot = Tot+a where Card = '" + textBox1.Text.Trim() + "'";
SqlCommand com = new SqlCommand(str, con1);
com.ExecuteNonQuery();
其余连库语句什么的都有,也都正确,我想问set后面可以写成Tot = Tot+a吗?怎么改才正确? 展开
string str= "update table(这是表名) set Tot = Tot+a where Card = '" + textBox1.Text.Trim() + "'";
SqlCommand com = new SqlCommand(str, con1);
com.ExecuteNonQuery();
其余连库语句什么的都有,也都正确,我想问set后面可以写成Tot = Tot+a吗?怎么改才正确? 展开
4个回答
展开全部
首先要明确的是同类型的数据变量才能进行运算,在T-SQL语句中同样适用。你要注意的是你的数据表中的字段Tot是什么类型的,大类型的+小类型的最后精确的是以大类型为准的。就比如C#中的float+int=int;(表达式表述的是类型运算与所得结果的类型),double + int = double;
所以,你的语句本身是有问题的,a是一个C#变量放到你的查询语句中的,首先你的语句就得修改成update table(这是表名) set Tot = Tot “+ a +” where Card = '" + textBox1.Text.Trim() + "'。
其次,你的Tot如果也是浮点型的,当然数据库中字段表现为decimal类型后面精确到一位,还是那句话,类型相同可直接做算术运算,如果不同,需要用convert转换成相同后再做运算。
所以,你的语句本身是有问题的,a是一个C#变量放到你的查询语句中的,首先你的语句就得修改成update table(这是表名) set Tot = Tot “+ a +” where Card = '" + textBox1.Text.Trim() + "'。
其次,你的Tot如果也是浮点型的,当然数据库中字段表现为decimal类型后面精确到一位,还是那句话,类型相同可直接做算术运算,如果不同,需要用convert转换成相同后再做运算。
展开全部
你这可以有多种方法,一是存储过程,参数为后面的card。二是分两个command,第一个查出现在的Tot值,用executescalar方法,得到后在内存里面加a,再拼凑新的sql语句。不能直接像你上面那样加的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
string str= "update table(这是表名) set Tot = Tot+ " +a+ " where Card = '" + textBox1.Text.Trim() + "'";
试试看行不行,另外a = float.Parse(label1.Text);这句话是多余的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不可以这么写吧。也应该和你Card后面那个那种格式写
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询