1. 首页 > 科技

sql 如何用 两个字符串中间的字符 作为查询条件? sql取字符串的第几个字符

sql 如何用 两个字符串中间的字符 作为查询条件?sql取字符串的第几个字符

SQLserver 怎么把查出的字符串结果作为子查询条件

展开全部

我先说下思路,等下可以详细讲

第一种方法你可以用一个自定义的分隔函数(表值函数)去得到001,002,003的三行记录

方法二:你可以逆向处理,如

select * from B

where (select top 1 A.U_NO+',' from A) like B.U_NO+','

加','是为了不会匹配错误

附上一个字符串分隔函数:

create function Split(@STR varchar(max),@Separator varchar(1000))

RETURNS @T TABLE(ID varchar(1000))

begin

if(len(@Separator)=0)

set @Separator=','

DECLARE @TName VARCHAR(1000)

SELECT @STR=RTRIM(@STR)+@Separator

WHILE CHARINDEX(@Separator,@STR)>0

BEGIN

SELECT @TName=LEFT(@STR,CHARINDEX(@Separator,@STR)-1)

SELECT @STR=STUFF(@STR,1,CHARINDEX(@Separator,@STR),'')

insert into @T(ID)values(@TName)

END

RETURN

end

go

sql语句, 字符串分割做为查询条件

SQL语句如下:

SELECT*

FROMA

WHERECHARINDEX(ID, '2,3,4') > 0

上述SQL语句在SQL Server中进行了测试。

SQL 提取两个字符之间的字符语句 帮帮忙

使用substring(),charindex()

然后配合使用case when then else end截取字符串

sql怎么用查询结果作为条件进行查询

嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。

1、单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。 例:

select ename,deptno,sal from emp

where deptno=(select deptno from dept where loc='NEW YORK');

2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。 例:

1).多行子查询使用IN操作符号例子:

查询选修了老师名叫Rona(假设唯一)的学生名字

sql> select stName from Student

where stId in(selectdistinct stId from score where teId=(select teId from teacher where teName='Rona'));

查询所有部门编号为A的资料: SELECT ename,job,sal FROM EMP

WHERE deptno in ( SELECT deptno FROM dept WHERE dname LIKE 'A%');

2).多行子查询使用ALL操作符号例子:查询有一门以上的成绩高于Kaka的最高成绩的学生的名字: sql> select stName from Student

where stId in(select distinct stId from score where score >all(select score from score where stId=(select stId from Student where stName= 'Kaka') )); 3). 多行子查询使用ANY操作符号例子:查询有一门以上的成绩高于Kaka的任何一门成绩的学生的名字:

sql> select stName from Student

where stId in(select distinct stId from score where score >any(select score from score where stId=(select stId from Student where stName='Kaka')));

希望能帮到你