SQL学习之使用order by 依照指定顺序排序或自己定义顺序排序

我们通常须要依据客户需求对于查询出来的结果给客户提供自己定义的排序方式,那么我们通常sql须要实现方式都有哪些,參考很多其它资料总结例如以下(不完好的和错误望大家指出):

一、假设我们仅仅是对于在某个程序中的应用是须要依照例如以下的方式排序,我们仅仅需在SQL语句级别设置排序方式:

1、依照oracled的默认方式排序:select * from table_name order
by  col_name  (desc|asc);(默觉得升序或无序对于升降仅仅有在数字字段);

2、依照自己定义的顺序排序:   select
* from table_name order by  decode(col_name,‘value1‘,1,value2‘,2,value3‘,3,value4‘,4,...valueN‘,N);

二、假设我们仅仅是对于在某个程序中的应用是须要依照例如以下设置的方式排序,我们仅仅需在SQL语句级别设置排序方式(一般没有设置之前我们系统的中文默认排序方式是依照拼音排序
  
):

1、依照拼音排序:   select * fromtable_name
order by  nlssort(col_name,‘NLS_SORT=SCHINESE_PINYIN_M‘);

2、依照笔划排序:   select * from table_name order by nlssort(col_name,‘NLS_SORT=SCHINESE_STROKE_M‘);

3、依照部首排序:   select * from table_name order by nlssort(col_name,‘NLS_SORT=SCHINESE_RADICAL_M‘);

注意:可是在数据量比較大情况下查询速度会非常慢,须要进行进一步优化。按oracle官方文档的解释,oracle在对中文列建立索引时,是依照2进制编码进行排序的,所以假设NLS_SORT被设置为BINARY时。排序则能够利用索引.假设不是2进制排序,而是使用上面介绍的3种针对中文的特殊排序,则oracle无法使用索引。会进行全表扫描.解决方法是,在此列上建立linguistic
index.比如:CREATE INDEX nls_index ON my_table (NLSSORT(name, ‘NLS_SORT = SCHINESE_PINYIN_M‘));

引用原文:Note:

Setting NLS_SORT to anything other than BINARY causes a sort to use a full table scan, regardless of the path chosen by the optimizer. BINARY is the exception because indexes are built according to a binary
order of keys. Thus the optimizer can use an index to satisfy the ORDER BY clause when NLS_SORT is set to BINARY. If NLS_SORT is set to any linguistic sort, the optimizer must include a full table scan and a full sort in the execution plan.

三、假设我们在整个会话中都要使用特定的方式排序的话,我们须要在Session级别的设置字段的默认排序方式:   

1.按拼音:alter session set nls_sort = SCHINESE_PINYIN_M;

2.按笔画:alter session set nls_sort = SCHINESE_STROKE_M;

3.按偏旁:alter session set nls_sort = NLS_SORT=SCHINESE_RADICAL_M;

四、假设我们须要对整个数据做指定的排序方式,就须要改动oracle server系统參数(一般这样的方式我们使用的比較少): 

1. win系统改动注冊表 HKLC\SOFTWARE\ORACLE\home0\NLS_SORT

2.其它改动配置set NLS_SORT=SCHINESE_RADICAL_M export NLS_SORT

时间: 2024-12-27 16:56:18

SQL学习之使用order by 依照指定顺序排序或自己定义顺序排序的相关文章

SQL学习之使用order by 按照指定顺序排序或自定义顺序排序

我们通常需要根据客户需求对于查询出来的结果给客户提供自定义的排序方式,那么我们通常sql需要实现方式都有哪些,参考更多资料总结如下(不完善的和错误望大家指出): 一.如果我们只是对于在某个程序中的应用是需要按照如下的方式排序,我们只需在SQL语句级别设置排序方式: 1.按照oracled的默认方式排序:select * from table_name order by  col_name  (desc|asc);(默认为升序或无序对于升降只有在数字字段); 2.按照自定义的顺序排序:   sel

SQL学习__基础教程

教程学习地点:http://www.w3school.com.cn/sql/ SQL是一种标准,一种技术方案,使得数据的存储,添加,查询等操作与使用者分离开,从而使用者不需要关注实现细节而可以广泛地在各种版本的RDBMS中使用(类似于封装). RDBMS是指关系型数据库管理系统(relation data base managing system).RDBMS中的数据存储在被称为表(tables)的数据库对象中.表是相关的数据项的集合,它由列和行组成. 一个数据库通常包含一个或者多个表,每个表由

MySQL数据库-SQL学习

1.引言 在开始sql学习之前,其实我之前有系统性的学习过数据库的知识,大概是在2年前.去年整整一年的时间从事的工作与数据库没有什么关联,现在重新开始一份开发工作,数据库学习是必要的技能,于是又来重头学习一下,就算"温故而知新"吧. 注:本次学习的资料来自于<SQL基础教程>第二版,正文主要是对本书学习的记录,常见的或自己非常熟悉的知识就不在本文列出了. 2.基础篇 第0章 主要讨论的是讨论的是如何搭建SQL学习环境,这个可以在网上搜索一大片的教程,搜索关键字“MySQL安

Oracle之PL/SQL学习笔记

自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家批评指正. PL/SQL定义:PL/SQL是由Oracle开发,专门用于Oracle的程序设计语言. PL---Procedural Language. SQL—Structure QueryLanguage.PL/SQL包括过程化语句和SQL语句     PL/SQL的单位:块. 一个块中可以嵌套

TERADATA SQL学习随笔&lt;一&gt;

最近在TERADATA环境学习SQL.在这里记录一下学习中查过的知识点,作为备案. 目录: 关于SQL学习及所用在线数据库 表联合 (join) SQL子查询 在select时创建新字段 (as, case when) 数据分组 (group by + 聚合函数count, sum, avg等) 利用over (partition by)进行数据分组并创建新字段 样本选择 1.关于SQL学习及所用在线数据库 之前有看过一些SQL学习的书.但如果从学习效率来说,跟着书学习SQL,不如直接看生产环境

sql学习笔记(15)-----------MySQL 索引与优化总结

索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点. 考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页面大小为4K,并存储100条记录.如果没有索引,查询将对整个表进行扫描,最坏的情况下,如果所有数据页都不在内存,需要读取10^4个页面,如果这10^4个页面在磁盘上随机分布,需要进行10^4次I/O,假设磁盘每次I/O时间为10ms(忽略数据传输时间),则总共需要100s(但实际上要好很多很多).如果对之建立B-Tree索引,则只需要进行log100(10^6

SQL学习笔记:选取第N条记录

Northwind数据库,选取价格第二高的产品. 有两种方法,一个是用Row_Number()函数: SELECT productname FROM (SELECT TOP 2 productname, Row_Number() OVER (ORDER BY unitprice desc) AS rownum FROM Products) AS tbl WHERE rownum = 2; 另一种是对子语句的的结果再进行排序: SELECT top 1 productname FROM (SELE

SQL学习_查询重复数据和连接多个表数据的方法

进行数据库测试时需要根据不同场景查询数据,以便验证发现的问题是否为脏数据引起的.记录一下最近常用的查询方法: 1. 查询表中重复数据(id不同,多个字段值相同) select P1.* from project as P1, project as P2 where P1.id<>P2.id and P1.ProjectId=P2.ProjectId and P1.ServiceTypeId=P2.ServiceTypeId and P1.Rank=P2.Rank 2.连接多个表数据 selec

SQL 学习日志03

添加表内容: insert into table_name (字段1,字段2,...) values (值1,值2,....) 查询表内容: select * from table_name select 字段1,字段2 from table_name select top 10 * from table_name select * from table_name where 字段=值 select * from table_name where 字段<>值 select * from tab