sql如何获取字符串中的指定字符

表tab中的aa列如下:asdfdsf?d=123&ewvqwer?d=234asfdwe?d=234&dhewuadfasf?d=25&reuwafhkashf如何获取... 表tab中的aa列如下:

asdfdsf?d=123&ewv
qwer?d=234
asfdwe?d=234&dhewu
adfasf?d=25&reuw
afhkashf
如何获取这些里的值d=123,d=234,d=25,求大神指导
展开
 我来答
freechan10
2019-12-12 · TA获得超过2.9万个赞
知道小有建树答主
回答量:263
采纳率:68%
帮助的人:12.4万
展开全部

1、创建测试表,

create table test_int(value varchar2(50));

2、插入测试数据

insert into test_int values('asdfdsf?d=123&ewv');

insert into test_int values('qwer?d=234');

insert into test_int values('asfdwe?d=234&dhewu');

insert into test_int values('adfasf?d=25&reuw');

insert into test_int values('afhkashf');

commit;

3、查询表中全量数据,select t.*, rowid from test_int t;

4、编写sql,获取字符串中的指定字符; 

select t.*,

       case

         when instr(value, 'd=') = 0 then

          null

         else

          substr(value,

                 instr(value, 'd='),

                 case

                   when instr(value, '&') = 0 then

                    10

                   else

                    instr(value, '&') - instr(value, 'd=')

                 end)

       end a

  from test_int t;

Andy_Sun321
推荐于2017-12-15 · TA获得超过1376个赞
知道小有建树答主
回答量:811
采纳率:89%
帮助的人:718万
展开全部

用函数实现会比较方便,如果是SQL Server的话,可以创建如下函数:

create function dbo.get01 (@s nvarchar(1000))
returns nvarchar(1000)
as
begin
 declare @idx int, @t nvarchar(1000)
 set @idx = charindex('?d=', @s)
 if @idx < 1
 begin
  set @idx = charindex('&d=', @s)
 end
 if @idx > 0
 begin
  set @t = right(@s, len(@s) - @idx)
  set @idx = charindex('&', @t)
  if @idx > 0
  begin
   set @t = left(@t, @idx - 1)
  end
 end
 return @t
end
go

调用示例:

select s.txt, dbo.get01(s.txt) as val
from (
 select 'adfasf?d=25&reuw' as txt
 union
 select 'sparetest?d=123&ewv'
 union
 select 'afhkashf'
 union
 select 'afdafda?b=c029&d=456'
) s

结果:

本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
高田沙希
2014-11-16 · TA获得超过130个赞
知道答主
回答量:114
采纳率:0%
帮助的人:111万
展开全部
select substring(字段,0,charindex('.',字段,0)+3) FROM 表 测试过的~
追问
这个根本就不能用
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
9iTreeNewBee
2014-11-17 · TA获得超过505个赞
知道小有建树答主
回答量:1800
采纳率:55%
帮助的人:418万
展开全部
SQL> insert into ckt1 values('asfdwe?d=234&dhewu');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from ckt1;

STR
--------------------------------------------------------------------------------
asfdwe?d=234&dhewu

SQL> select instr(str,'d=') loc from ckt1;

LOC
----------
8

SQL> select instr(str,'d=') starloc,instr(str,'&') endloc from ckt1;

STARLOC ENDLOC
---------- ----------
8 13

SQL> select substr(str,instr(str,'d='),instr(str,'&')) newstr from ckt1;

NEWSTR
--------------------------------------------------------------------------------
d=234&dhewu

SQL> select substr(str,instr(str,'d='),instr(str,'&')-instr(str,'d=')) newstr from ckt1;

NEWSTR
--------------------------------------------------------------------------------
d=234

这样应该可以
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式