数据库的求和,如果我的一列是用VARCHAR类型,保存的数据比如是339,369这样的金额数据,怎么才能相加?

 我来答
hit_lubin
推荐于2017-11-24 · TA获得超过7889个赞
知道大有可为答主
回答量:1554
采纳率:100%
帮助的人:2079万
展开全部
从你的VARCHAR类型来看,不是ORACLE的数据库
ORACLE数据库是使用TO_NUMBER()来实现字符到数字的转换的。不过ORACLE里面这个类型叫VARCHAR2或者CHAR
你的应该是SQLSERVER一类的数据库吧?
select sum(CAST(列名 AS INT)) from 表
如果金额有小数位,那就把INT改成DECIMAL(10,2)这样
更多追问追答
追问
是SQLserver05的,金额是339,369,中间有逗号,也就是339369,也能用吗?麻烦你了
追答
不能用,要先把逗号去掉,用REPLACE函数试试
select sum(CAST(REPLACE(列名,',','') AS INT)) from 表
先把逗号去掉,然后转化成数字,在做加
畅夏侯岚0O
2011-04-21 · 超过51用户采纳过TA的回答
知道小有建树答主
回答量:123
采纳率:0%
帮助的人:68.4万
展开全部
select sum(to_number(字段名)) from 表
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式