‘壹’ sql IN 字符串查询 急
如果真的只三条,你还不如直接写
select * from t1 WHERE id='3' or id='4' or id='5' order by id
我很想问的是,你id这个字段是什么类型?
或者你用like吧,但是like不一定准,
select * from t1 WHERE id like '% & $name & %'
in 一般是用在针对数组,而你的 $name 只是一个字符串,除非你先拆成数组。
以上仅供参考
‘贰’ sql语句中in的用法
IN 操作符允许我们在 WHERE 子句中规定多个值。
SQL IN 语法:
SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...)
(2)sql字段in一个字符串扩展阅读:
1、IN 与 = ANY 等价,均表示,变量在(子查询)列表之中,即 a IN (table B) 表示 a = ANY B.b
2、NOT IN 与 <> ALL 等价,而不等于<> ANY,前两者均表示,变量不在(子查询)列表之中,即 a NOT IN (table B) 表示 a <> ALL B.b。而如果a <> ANY B.b,则只要任意一个b<>a就true了。
3、IN 与 EXISTS 的性能区别主要来自,IN 会编列子查询的每行记录,然后再返回,而EXISTS 则只要遇到第一个满足条件的记录就马上返回。
‘叁’ SQL子查询中,当IN遇到字符串
管理
ID 城市
5 '北京','上海'
你这个实际上是一个字符串
查询的时候,将“'北京','上海'”当成一个字符串查询,所以查询不出来
select id,城市 from 地区 where (select 城市 from 管理 where id=5) like '%'+城市+'%'
‘肆’ sql in()语句
你这样构造in的范围不对。你这样是把in后面处理成一个字符串了。而in后面跟的应该是一个范围。
你可以自己写一个返回数据集的函数来将aa.ddid值处理成in的范围,
类似于:
假设函数:
ft01(nvarchar(1000))
returns
table
tb
(val
int)。
那么,
这样更新里面子查询的in条件:
where
id
in
(select
val
from
ft01(aa.ddid))。
另外,
此解决方法只是从in条件上来说。
如果子查询只有1条记录,in和=是没有区别,如果子查询有多条记录,用=会出错的,所以in是无论只查询有多少条记录都可以使用,而=只有当子查询只有1条记录的时候才能使用。
in和exists理解上其实是差不多,但对数据库而言,in的执行顺序是先执行只查询条件,然后把记录和外查询核对,找符合条件的。
而exists是先执行外查询,再执行子查询,找到外查询记录后和只查询对比符合条件的,如果外查询和子查询的条目数差异很大,那么效率相差很明显的。
‘伍’ SQL中in传入字符串处理方法
这里说到的in方法,例如:
select * from Students where ID in ('111', '222', '333');
或者
select * from Students where Name in ('张三', '李四', '王五');
declare @sql varchar(1000)
set @sql = 'select * from Students where 1=1 '
set @sql = @sql + ' and ID in ('+ @整型参数+') '
declare @sql varchar(1000)
declare @strLen int
declare @next int
declare @where varchar(1000)
set @sql = 'select * from Students where 1=1 '
if(@userId<> '')
begin
set @strLen= dbo.Get_StrArrayLength(@userId,',')
set @next=1
set @where=''
if(@strLen > 0) begin
set @sql=@sql+' AND (UserID IN ('
while @next<=@strLen begin
set @where=@where+ ','''+ dbo.Get_StrArrayStrOfIndex(@userId,',',@next) +''''
set @next=@next+1
end
if(LEN(@where) > 3) begin
set @where= SUBSTRING(@where, 2, LEN(@where))
end
set @sql=@sql + @where +'))'
end
end
‘陆’ sqlserver中想用in判断范围,但只能输入一个字符串参数,如何拆字符串然后动态拼in()里面的内容呢
字符串应该类似'a,b,c,d' 或者'1,2,3,4'这样的吧?
拼字符串 set @str='select * from tb where 字段 in ('+char(39)+replace('字符串',',',char(39)+','+char(39)))+char(39)+')'
exec(@str)
就是把'a,b,c,d' 替换成 ('a','b','c','d')
‘柒’ sql in 字符串
没大懂你的意思..
是不是
Split(',')...??然后可以得到每个子字符串.
然后再 in 每个子字符串.
-------------------
string str="abc,cde,egf";
string[] val=str.Split(',');
string newstr="";
for(int ii=0;ii<val.Length;ii++){
newstr=newstr+"'"+val[ii]+"'"+",";
}
newstr=newstr.SubString(0,newstr.Length-1);//去掉最后一个逗号
//得newstr值为:'abc','cde','egf'
------------------
不用在存储过程里实现...你在程序里把字符串处理成上面的那样儿.然后再使用存储过程.传的参数是处理后的字符串.
‘捌’ in在sql中是什么意思
select * from table where id in (1,3,5)
查询表里 id 是1 或者3 或者5 的记录
select * from table where name in ('小明','小红','小丽')
查询表里 name 等于 小明 或者小红 或者 小丽的记录
还有not in