我数据库A里面有一个字段B的值为123:456,我只想查出123,怎样写SQL语句啊

 我来答
wanzhongwen19
2014-01-03 · 知道合伙人互联网行家
wanzhongwen19
知道合伙人互联网行家
采纳数:112 获赞数:870
毕业于湖南吉首大学,学士学位。从事web行业五年经验,现任中国燃气集团担任前端开发工程师

向TA提问 私信TA
展开全部

这个其实有两种写法,用到二个字符串截取函数


  1. select left(B,3) from A

  2. select substring(B,1,3) from A

  即可实现你需要的功能。

追问
可是“:”前面的字符不确定有几个,是随机的
追答
刚才仔细想了一下,经过测试,给出了另外一个思路,具体的给代码吧

select substring(B,CHARINDEX('123',B),3) from A 这个思路就是,我先charindex函数算出123的位置,然后利用substring函数从charindex函数得出的位置,来查出123,完美搞定。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
上善若水7543
2014-01-03
知道答主
回答量:35
采纳率:0%
帮助的人:15.4万
展开全部
楼上的瞎说,别人是要:号之前的,没说是1-3位置的。
select t.b,substr(t.b,0,instr(t.b,':')-1) from A t;
用instr 函数取出你:号所在的下标位子,在用substr去截取
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tj_angela
2014-01-03 · TA获得超过7530个赞
知道大有可为答主
回答量:6797
采纳率:75%
帮助的人:2564万
展开全部
select substring(b,1,3) from table_name
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式