日期:2014-05-18 浏览次数:20674 次
这么长的in..
CREATE TABLE #T(id int identity,val int)
INSERT #T(val) VALUES(31132)
INSERT #T(val) VALUES(47100)
select *
from tab as a
join #T as b
on a.id=B.val
where a.price<99.0
order by b.id
------解决方案--------------------
类似这样:
order by charindex(','+ltrim(id)+',',',31132,47100,35675,34210,35119,')
------解决方案--------------------
SELECT
*
FROM
tab
WHERE
price>5.0
AND
price <99.0
AND
id IN (31132,47100,35675,34210,35119,37173,37394,45293,45310,32570,36533,34140,35586,45276,45284,45303,42480,42498,38318,39710,41485,42573,26838,41785,42089,38522,40519,43023,43719,38303,40456,40638,40838,34262,35186,27546,27549,27550,27554,28321,28323,28332,26652,37719,42516,43286,43935,43938,26024,26811,27708,28368,37603,40437,43239,43342,43809,43978,25996,26023,26145,26151,26289,26417,26420,27107,27116,27146,27502,27522)
ORDER BY
CHARINDEX(','+LTRIM(ID)+',',',31132,47100,35675,34210,35119,37173,37394,45293,45310,32570,36533,34140,35586,45276,45284,45303,42480,42498,38318,39710,41485,42573,26838,41785,42089,38522,40519,43023,43719,38303,40456,40638,40838,34262,35186,27546,27549,27550,27554,28321,28323,28332,26652,37719,42516,43286,43935,43938,26024,26811,27708,28368,37603,40437,43239,43342,43809,43978,25996,26023,26145,26151,26289,26417,26420,27107,27116,27146,27502,27522,')
------解决方案--------------------
先建临时表
1.如果无重复ID的话且长度小于10000的话
写入用字符串 用CHARINDEX(5楼)来做
2.如果有重复ID的话
建一个序列sq来建数据序列
再从临时表里取出
------解决方案--------------------
----测试表名loginlog
select loginlog.loginid,loginlog.userid ----这里是你要查询的字段列表
from
(select 197 as loginid,1 as id
union
select 188,2
union
select 195,3
----你有多少条件就union上多少条件,但这个临时表的id必需有序,
) as temptable 临时union一个表
,loginlog ----要查询的表名
where temptable.loginid=loginlog.loginid and loginlog.userid='libeibei'----这里加你想要的条件
order by temptable.id