方法一:
比如需要对SQL表中的字段NAME进行如下的排序:
张三(Z)
李四(L)
王五(W)
赵六(Z)
按照sql中的默认排序规则,根据字母顺序(a~z)排,结果为:李四 王五 赵六 张三
自定义排序:order by charindex(NAME,‘张三,李四,王五,赵六’)
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问题。
方法二:
针对表table_example的class字段排序,class字段值为:A、B、C、D。用户要求table_example中的数据按照class字段值C、A、D、B的顺序排序。
select * from teble_exaple
order by(
case class
when 'C' then 1,
when 'A' then 2,
when 'D' then 3,
when 'B' then 4
else ''
方法三:
利用decode函数: select * from table_example order by decode(class,‘C’,1,‘A’,2,‘D’,3,‘B’,4)
SELECT BBNAME,BBTYPE,DECODE(BBTYPE, '1', 1, '2', 2, '4', 3, '5', 4, '3', 5)BBTYPE_SORT,REPORTDATE,ISALLREPORY
FROM TEMP
ORDER BYBBTYPE_SORT
decode含义解释
decode(条...
赵六(Z)
按照sql中的默认排序规则,根据字母顺序(a~z)排,结果为:李四 王五 赵六 张三
自定义排序:order by charindex(NAME,‘张三李四王五赵六’)
CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:
CHARIN...
insert into temp(id,name,age) values(1,'tom',22)
insert into temp(id,name,age) values(2,'bob',23)
insert into temp(id,name,age) values(3,'timi',24)
select * from temp
我们通常需要根据客户需求对于查询出来的结果给客户提供自定义的排序方式,那么我们通常sql需要实现方式都有哪些,参考更多资料总结如下(不完善的和错误望大家指出):
一、如果我们只是对于在某个程序中的应用是需要按照如下的方式排序,我们只需在SQL语句级别设置排序方式:
1、按照oracled的默认方式排序:select * from table_name order
by col_n
实际应用中sql提供的默认按某一字段排序,asc、desc并不满足需要,需要根据用户需求自定义的按照默写顺序排序,这里提供一个方法,适用于自定义类型不多的情况下,多了就得存字段关联表排序了吧。
例子如下:
select * from
select 3 as id,'小明' as name from dual
union
select 1,'小王' from dual
un...
最近有个需求是对sql的结果集list进行排序,因为list默认查出的结果排序是按该表id索引的顺序查找的,所以顺序也是按索引顺序排列,如果想让list按自己的结果显示,那么有两个方法:
1,将in语句拆成 union 的方法,此处就不多说了
2,在网上看到 instr 的函数来进行排序,这里我想要说的是在hql中拼接该语句时候赢注意的问题
先看一下 例句:
SELECT * F
Review:等待回复
Finish:任务完成
按日期和状态排序,先状态为:提交请求(Apply)—按时间倒序,然后状态为:等待回复(Review)—按时间倒序,然后状态为:任务完成(Finish)—按时间倒序。
DROP TABLE IF EXISTS `customsort`;
CREATE TABLE `customsort` ( `status` VARCHAR ( 255 ), `date1` date );
在做项目页面显示中,有时需要按照指定字符串顺序排序,根据检索条件把检索结果排序。SqlServer 的charindex 语法可以实现对字段按照指定的顺序排序。
order by 中包含的条件在其他数据之前
select * from 表名
where 列名 in ('条件1','条件2','条件3')
order by charindex(列名,'条件1条件2') -- 注意: 条件1条件2 中间没有隔开
例如: 1.表Test字段栏位 :status,id , type..... 查询..
SQL Server 自定义查询分析器规范包括以下几个方面:
1. 查询分析器窗口规范:查询分析器窗口应该包括查询编辑器窗口、结果窗口和消息窗口。查询编辑器窗口用于编写 SQL 查询语句,结果窗口显示查询结果,消息窗口用于显示查询执行过程中的消息和错误信息。
2. 查询编辑器规范:查询编辑器应该支持 SQL 语法高亮显示、自动缩进、自动补全、代码提示等功能,同时还应该支持多个查询编辑器窗口。
3. 查询结果窗口规范:查询结果窗口应该支持多个结果集的显示,同时还应该支持结果集的排序、筛选、分组、合并等功能。
4. 查询执行计划规范:查询分析器应该支持查询执行计划的生成和查看,同时还应该支持查询执行计划的分析和优化。
5. 查询历史记录规范:查询分析器应该支持查询历史记录的保存和管理,包括查询时间、查询语句、执行结果等信息。
6. 插件扩展规范:查询分析器应该支持插件扩展,允许用户根据自己的需求添加新的功能和工具。
以上是 SQL Server 自定义查询分析器规范的主要内容,开发人员应该按照这些规范进行开发,以提高查询分析器的功能和性能。