我在“名称”列中有一个包含值的文本列表
Name
J001500
J001510
J001520
J001600
J001610
J001620
J001700
J001710
J001720
J001800
J001810
J001820
要从起始表格J0016xx到J0017xx 的范围内进行选择, 我怎样才能做到这一点?除了以下方法:
WHERE Name BETWEEN 'J0016%' AND 'J0017%'
ORDER by Name
欢迎使用普通的SQL和Regex方式。
答案 0 :(得分:2)
with test as (select 'J001500' as name from dual union
select 'J001510' from dual union
select 'J001520' from dual union
select 'J001600' from dual union
select 'J001610' from dual union
select 'J001620' from dual union
select 'J001700' from dual union
select 'J001710' from dual union
select 'J001720' from dual union
select 'J001800' from dual union
select 'J001810' from dual union
select 'J001820' from dual)
--select * from test where name >= 'J0017' and name < 'J0018'
select * from test where name between 'J0017' and 'J0018'
答案 1 :(得分:2)
(1)基于LIKE
运算符和_
(代表一个字符)
WHERE Name LIKE 'J0016__' OR Name LIKE 'J0017__'
(2)基于字符串的字母数字排序也可以,但是不能确保在指定文本之后还有两个以下字符:
WHERE Name BETWEEN 'J0016' AND 'J0018' -- note 18 here which means < 'J0018'
(3)将REGEXP_LIKE
Oracle函数与区分大小写的搜索一起使用:
WHERE REGEXP_LIKE(Name, '^J001[67].{2}$','c')
说明:
^J001
-以J001开头[67]
-下一个字符为6或7 .{2}$
-以两个字符结尾我个人选择(1)或(3)只是因为它在需要修改条件时(例如字符串中的数字,因为(2)可能会中断并且需要您进行更改)更加防弹争论的地方)。如果您要考虑可移植性,那么(1)中的LIKE
是一个更好的选择,因为(3)是特定于产品的。
答案 2 :(得分:1)
逻辑:提取字符串中的第4个和第5个字符,如果介于16和17之间,则将其作为输出。
我不知道您使用的是哪个RDMS。我可以根据您的RDBMS对其进行修改。下面的查询将在SQL Server中工作
SELECT *
FROM table
WHERE CONVERT(INT,SUBSTRING(name,4,2)) BETWEEN '16' AND '17'
ORDER by Name
答案 3 :(得分:1)
最好的方法是:
WHERE Name >= 'J0016' AND Name < 'J0018'
为什么这是“最好的”?首先,它返回正确的值,并且不会引起误解。使用BETWEEN
具有误导性,因为'J0018'
将包含在结果中(尽管如果有其他字符则不会包含在内)。
第二,优化器可以利用查询的索引(如果有)。