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吗?怎么改才正确?
展开
 我来答
super_syc
2013-12-11 · TA获得超过105个赞
知道小有建树答主
回答量:122
采纳率:0%
帮助的人:145万
展开全部
首先要明确的是同类型的数据变量才能进行运算,在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转换成相同后再做运算。
阳光的雷咩咩
2013-12-11 · TA获得超过1.4万个赞
知道大有可为答主
回答量:2.3万
采纳率:66%
帮助的人:7817万
展开全部
你这可以有多种方法,一是存储过程,参数为后面的card。二是分两个command,第一个查出现在的Tot值,用executescalar方法,得到后在内存里面加a,再拼凑新的sql语句。不能直接像你上面那样加的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
怪微风太温柔Cide1
2013-12-11 · TA获得超过153个赞
知道小有建树答主
回答量:211
采纳率:0%
帮助的人:179万
展开全部
 string str= "update table(这是表名) set Tot = Tot+ " +a+ " where Card = '" + textBox1.Text.Trim() + "'";

试试看行不行,另外a = float.Parse(label1.Text);这句话是多余的

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
auag0113
2013-12-11
知道答主
回答量:6
采纳率:0%
帮助的人:8814
展开全部
不可以这么写吧。也应该和你Card后面那个那种格式写
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式