一个很急的难题,求助高手!

power6d 2009-03-30 11:54:49
一张表,有一个字符串型的字段,里面全是分数(例如:1/3 , 1/4 , 1/5).
我想直接取出里面的计算结构,该怎么写SQL语句(不能用游标).

结果是数值型的(例如:0.33333,0.25,0.2)
...全文
60 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
百年树人 2009-03-30
  • 打赏
  • 举报
回复
declare @sql varchar(1000)

select @sql='select ltrim((select '+replace(replace('1/3,1/4,1/5','/','.0/'),',','))+'',''+ltrim((select ')+'))'

exec(@sql)

/**

------------------------------------
0.333333,0.250000,0.200000

**/
百年树人 2009-03-30
  • 打赏
  • 举报
回复
declare @sql varchar(1000)

select @sql='select '+replace(replace('1/3,1/4,1/5','/','.0/'),',',' union all select ')

exec(@sql)

/**

---------
.333333
.250000
.200000
**/
dawugui 2009-03-30
  • 打赏
  • 举报
回复
create table tb(col varchar(10))
insert into tb values('1/3')
insert into tb values('1/4')
insert into tb values('1/5')

go
select left(col , charindex('/' , col) - 1) * 1.0 /
substring(col,charindex('/' , col) + 1 , len(col))
from tb
where charindex('/' , col) > 1

/*

---------------
.33333333
.25000000
.20000000

(所影响的行数为 3 行)
*/

drop table tb
dawugui 2009-03-30
  • 打赏
  • 举报
回复
[Quote=引用楼主 power6d 的帖子:]
一张表,有一个字符串型的字段,里面全是分数(例如:1/3 , 1/4 , 1/5).
我想直接取出里面的计算结构,该怎么写SQL语句(不能用游标).

结果是数值型的(例如:0.33333,0.25,0.2)
[/Quote]

这个比较麻烦,要先分解,然后还要按'/'取数据来计算.
htl258_Tony 2009-03-30
  • 打赏
  • 举报
回复
create table tb(col varchar(10))
insert into tb values('1/3')
insert into tb values('1/4')
insert into tb values('1/5')

go
select left(col,charindex('/',col)-1)*1.0/right(col,len(col)-charindex('/',col)) from tb
/*
---------------------------------------
0.33333333
0.25000000
0.20000000

(3 行受影响)
*/
drop table tb
htl258_Tony 2009-03-30
  • 打赏
  • 举报
回复
select left(col,charindex('/',col)-1)*1.0/right(col,len(col)-charindex('/',col))

22,181

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧