快手业务免费自助下单平台网站,快手查看别人的双击,免费领快手一粉丝软件

让sql语句结果集不排序,按照in语句的顺序返回结果

本项目,使用数据为 sql server 2008

比如 sql语句为

select * from order where oderid in(111,222,333,444,555,666)

数据为

id name

111 C

222 D

333 R

444 F

555 W

666 K

——————————————————————

select name from order where oderid in(111,222,333,444,555,666)

order by instr('111,222,333,444,555,666',orderid)

instr是orale里面表示字串出现位置的一个函数.DB2应该也有这样的函数

——————————————————————

因此查阅相关资料,发现SQLServer中的CHARINDEX函数功能与ORACLE中instr功能相似

1)SQLServer中的 CHARINDEX

CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:

CHARINDEX ( expression1 , expression2 [ , start_location ] )

Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。

CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数整数“0”。让我们看看下面的函数命令执行的结果:

CHARINDEX('SQL', 'Microsoft SQL Server')

这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。

下来,我们看这个CHARINDEX命令:

CHARINDEX('7.0', 'Microsoft SQL Server 2000')

在这个例子中,CHARINDEX返回零,因为字符串“7.0” 不能在“Microsoft SQL Server”中被找到。接下来通过两个例子来看看如何使用CHARINDEX函数来解决实际的T-SQL问题

SELECT code, rate from ge WHERE code IN ('s', 'h') order by CHARINDEX('sg,hk', code)

上面的写法出错。最终是:

SELECT code, rate from ge WHERE code IN ('s','a','h') order by CHARINDEX(','+LTRIM(code)+',',',s,a,h,')

测试在 sql server 2008 正确。

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注