1.
比如需要对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问题。

2.
针对表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 ‘’
end
)

3.
利用decode函数: select * from table_example order by decode(class,‘C’,1,‘A’,2,‘D’,3,‘B’,4)

SQL server数据库语句自定义排序相关推荐

  1. Excel VBA通过ADO连接、操作SQL Server数据库的自定义函数

    网上大多数有关VBA连接.操作SQL Server数据库的教程,大多是把连接字串.SQL语句.执行过程全写在一个过程中了,当一个VBA项目需要做大量的查询.更新数据时,显然这种方法并不合适,以下代码是 ...

  2. sql server数据库 T-SQL查询语句(基本篇)

    接上篇sql server 数据库增删改查(库与表) 删除数据 delete 表名 where 查询条件 T-sql查询语句 T-sql语句 增强版的sql语句,增加了更多的函数应用,流程控制,变量说 ...

  3. SQL Server数据库查询区分大小写、全半角——排序规则的应用(转载)

    SQL Server数据库查询区分大小写.全半角--排序规则的应用 因为偶然的原因,需要在INNER JOIN联表时,让对应字段进行区分大小写的比较.而默认情况下建立的Sql Server数据库是不区 ...

  4. Visual C#使用ADO.NET自定义类MyDBase连接SQL Server数据库

    本文为Visual C#使用ado.net技术跟SQL Server数据库交互的自定义类MyDBase,通过该类,可以快速高效的实现数据库的连接.获取数据集.获取数据的个数.执行SQL语句等.例如,连 ...

  5. SQL Server中使用自定义指定顺序排序

    SQL Server中使用自定义指定顺序排序 原文:SQL Server中使用自定义指定顺序排序 比如需要对SQL表中的字段NAME进行如下的排序: 张三(Z) 李四(L) 王五(W) 赵六(Z) 如 ...

  6. html连接数据库id号自动生成器,SQL Server数据库sql语句生成器(SqlDataToScript)的使用(sql server自增列(id)插入固定值)...

    SqlDataToScript是根据表数据进行生成 Insert Into语句,此工具还有一个好处是可以对自增列插入固定值,例如:自增的列id值为5,但是5这个行值已经删除,如果想存储Id自增列值为5 ...

  7. 修改sql服务器排序规则,SQL SERVER数据库服务器排序规则修改

    SQL Server服务器修改排序规则的方法 操作及验证步骤: 1 登录数据库后,查看当前安装数据库默认排序规则的两种方式 方式一.使用SQL Server 2014 Management Studi ...

  8. SQL Server数据库迁移–将数据库克隆到另一个排序规则

    Database migration is a vital task in any environment, complex or otherwise. Seamless migrations are ...

  9. SQL Server数据库存储过程——以自定义存储过程为例

    SQL Server数据库存储过程--以自定义存储过程为例 1.什么是数据库存储过程 存储过程就是预编译SQL语句的集合,这些语句存储在一个名称下并作为一个单元处理.存储过程代替了传统的逐条执行SQL ...

最新文章

  1. python常见的数据类型_Python常见数据类型及操作
  2. 【Scratch】青少年蓝桥杯_每日一题_4.25_说日子
  3. 深度学习在CV领域的进展以及一些由深度学习演变的新技术
  4. CDH Kerberos 认证下Kafka 消费方式
  5. 利用IDisposable接口构建包含非托管资源对象
  6. css-bootstrap的安装与使用
  7. json_decode()和json_encode()区别----2015-0929
  8. nodejs实践录:开篇
  9. 云南民大java期中考试_中南民族大学Java语言程序设计期末试卷A卷
  10. 保障电邮EMAIL通讯的安全性
  11. 用indy收邮件的问题,怎么样把邮件存放到本地,最好是存到数据库
  12. 在Windows Server 2003企业版下让移动硬盘自动显示盘符
  13. 怎么让两个java文件关联,怎么把多个excel文件合并成一个【几个excle合并成一个】...
  14. vim常用插件安装及使用
  15. Zotero 和它的朋友们: 一个文献阅读生态
  16. ROS自定义消息类型,编译无法生成 msg/srv 文件产生的头文件
  17. 【实习日志】SSM用户管理系统搭建+更新
  18. matlab绘制图形hold on_MATLAB中hold on和figure的区别?画三维图为什么一定要meshgrid?...
  19. c语言asinh函数,C ++ STL中的asinh()函数
  20. test STM32F407 ETH RMII

热门文章

  1. xlwings不可见地操作excel
  2. python粗糙集简约算法+可视化界面
  3. Linux 内核 C 语言深度解析
  4. 微信、QQ称霸社交,多闪能否上位?
  5. 网页通过iframe嵌入百度地图API时自适应屏幕
  6. NTLM及Kerberos认证流程
  7. 阿里巴巴字体图标iconfont使用
  8. 程序员最关心的是什么
  9. 网站页面中常见的色彩所表达的意义是什么?
  10. Linux操作系统简介