我数据库A里面有一个字段B的值为123:456,我只想查出123,怎样写SQL语句啊
3个回答
2014-01-03 · 知道合伙人互联网行家
关注
展开全部
这个其实有两种写法,用到二个字符串截取函数
select left(B,3) from A
select substring(B,1,3) from A
即可实现你需要的功能。
追问
可是“:”前面的字符不确定有几个,是随机的
追答
刚才仔细想了一下,经过测试,给出了另外一个思路,具体的给代码吧
select substring(B,CHARINDEX('123',B),3) from A 这个思路就是,我先charindex函数算出123的位置,然后利用substring函数从charindex函数得出的位置,来查出123,完美搞定。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼上的瞎说,别人是要:号之前的,没说是1-3位置的。
select t.b,substr(t.b,0,instr(t.b,':')-1) from A t;
用instr 函数取出你:号所在的下标位子,在用substr去截取
select t.b,substr(t.b,0,instr(t.b,':')-1) from A t;
用instr 函数取出你:号所在的下标位子,在用substr去截取
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select substring(b,1,3) from table_name
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询