日期:2014-05-18 浏览次数:20575 次
这么长的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