远程Sybase数据库技术支持,联系手机:13811580958,QQ:289965371!

 

随着Sybase被完全整合到SAP下,Sybase原来的支持网站被SAP Support Portal取代。
只有购买了SAP服务的用户才能使用账号登录SAP Support Portal进行介质下载、补丁升级、报Incident等。
目前,原Sybase所有产品(包括:Adaptive Server Enterprise、Sybase IQ、Replication Server、PowerDesigner等)的官方手册仍然可以从http://infocenter.sybase.com/help/index.jsp进行浏览或下载。暂不清楚该网站http://infocenter.sybase.com/help/index.jsp何时会被完全迁移到SAP Support上!
Sybase官方手册英文版有html和pdf两种格式,而中文版手册只有pdf一种格式。为了国内Sybase用户更方便、快捷地搜索Sybase常见产品的官方手册内容,特将中文版Sybase官方手册转为html格式!
Sybase产品官方手册中文版的html格式所有内容的版权归SAP公司所有!本博客站长是Sybase数据库的铁杆粉丝!

如有Sybase数据库技术问题需要咨询,请联系我!

  QQ :289965371 点击这里给我发消息
  Email:

以下官方手册为ASE 15.7 ESD#2中文版:

  1. 新增功能公告 适用于 Windows、Linux 和 UNIX 的 Open Server 15.7 和 SDK 15.7
  2. 新增功能摘要
  3. 新增功能指南
  4. ASE 15.7 发行公告
  5. 配置指南(windows)
  6. 安装指南(windows)
  7. 参考手册:构件块
  8. 参考手册:命令
  9. 参考手册:过程
  10. 参考手册:表
  11. Transact-SQL® 用户指南
  12. 系统管理指南,卷 1
  13. 系统管理指南,卷 2
  14. 性能和调优系列:基础知识
  15. 性能和调优系列:锁定和并发控制
  16. 性能和调优系列:监控表
  17. 性能和调优系列:物理数据库调优
  18. 性能和调优系列:查询处理和抽象计划
  19. 性能和调优系列:使用 sp_sysmon 监控 Adaptive Server
  20. 性能和调优系列:利用统计分析改进性能
  21. 程序员参考 jConnect for JDBC 7.0.7
  22. Adaptive Server Enterprise 中的 Java
  23. 组件集成服务用户指南
  24. Ribo 用户指南
  25. 内存数据库用户指南
  26. Sybase Control Center for Adaptive Server® Enterprise
  27. 安全性管理指南
  28. 实用程序指南

 


< 上一个 | 内容 | 下一步 >

order by 子句

说明 按排序顺序返回指定列中的查询结果。

语法 [Start of select statement

[order by

{[table_name.| view_name.]

column_name | select_list_number | expression} [asc | desc]

[,{[table_name.| view_name.]

column_name | select_list_number | expression} [asc | desc]]...]

[End of select statement

参数 order by

按列对结果进行排序。

asc

按升序顺序排列结果。如果未指定 asc desc,则使用 ascdesc

按降序顺序排列结果。

示例 示例 1 选择价格高于 $19.99 的书名,并将书名按字母顺序与价格一起列 出:

select title, type, price from titles

where price > $19.99 order by title

title

type price

---------- ---------- ---------- ---------- --------- ---------- -

------------ -------------------------

But Is It User Friendly?

popular_comp 22.95

Computer Phobic and Non-Phobic Individuals:Behavior Variations psychology 21.59

Onions, Leeks, and Garlic:Cooking Secrets of the Mediterranean trad_cook 20.95

Secrets of Silicon Valley

popular_comp 20.00

示例 2 按类型的降序字母顺序列出 titles 表中的书,并计算每种类型的平 均价格和平均预付款:

select type, price, advance from titles


order by type desc

compute avg (price), avg (advance) by type

示例 3 列出 titles 表中的 title ID 和预付款除以总销售额得到的值,按计算 得到的最低值到最高值顺序排列:

select title_id, advance/total_sales from titles

order by advance/total_sales

title_id

-------- ------------------------ MC3026 NULL

PC9999 NULL

MC2222 0.00

TC4203 0.26

PS3333 0.49

BU2075 0.54

MC3021 0.67

PC1035 0.80

PS2091 1.11

PS7777 1.20

BU1032 1.22

BU7832 1.22

BU1111 1.29

PC8888 1.95

TC7777 1.95

PS1372 18.67

TC3218 18.67

PS2106 54.05

示例 4 按类型顺序列出书名和类型,并在输出中重命名各个列:

select title as BookName, type as Type from titles

order by Type

用法 order by 按顺序在指定列中返回查询结果。order by 属于 select 命令的 一部分。

Transact-SQL 中,可以使用 order by 对未出现在 select 列表中的项 进行排序。可以按照列标题、列名、表达式、别名 (如果已在 select 列表中指定)或表示项目在 select 列表中位置的数字 ( select_list_number ) 进行排序。

如果按 select_list_number 排序,则 order by 子句引用的列必须包括在

select 列表中,且 select 列表不能为 * (星号)。


使用 order by 以有意义的顺序显示查询结果。如果没有 order by 子 句,则无法控制 Adaptive Server 返回结果的顺序。

存在相同的表列名和列别名时 order by 的行为

存在以下三个条件时,Adaptive Server 会将 order by 子句中的列名解释为 别名:

order by 子句包含对限定列名的引用 (即 order by table.column )。

表列名和别名同时存在。

表列名和别名都与 order by 子句中的列名相同。

在以下示例中,尽管 order by 子句相同,但两个查询的结果集也是不同 的;而且 order by 子句在两种情况中引用的列也不同。

create table t (A int, B char(3)) insert into t (A, B) values(1, 'az') insert into t (A, B) values(2, 'bb') go

/* t.B refers to the table column B */ select A, reverse(B) as C from t order by t.B go

/* t.B refers to the alias column B */ select A, reverse(B) as B from t order by t.B go

A C

----------- ---

1 za

2 bb

(2 rows affected) A B

----------- ---

2 bb

1 za


(2 rows affected)

出现这种行为的原因是,Adaptive Server 允许 order by 子句引用由表名限 定的别名列名。当存在列名与别名列相同的基表列时, Adaptive Server 会为别名列提供更高的优先级。

限制

order by 子句所允许的最大列数是 31 列。

不能对 textunitext image 数据类型的列使用 order by


子查询和视图定义中不能包含 order by 子句,也不能包含 compute 子 句和 into 关键字。反之,在 order by 列表中也不能使用子查询。

如果服务器或语言类型游标的 select 语句中包含 order by 子句,则不 能更新该游标的结果集。有关应用于可更新游标的限制的详细信 息,请参见 《Transact-SQL 用户指南》。

如果使用 compute by,必须同时使用 order by 子句。在 compute by 之 后列出的表达式必须与 order by 后面列出的表达式相同或是其子集, 它们从左向右的顺序必须一致,必须以同一表达式开始且不可跳过 任何表达式。例如,假设 order by 子句为:

order by a, b, c

compute by 子句可以是下列任何一种或全部形式:

compute by a, b, c compute by a, b compute by a

compute 关键字也可以不与 by 连用,以生成总和、总计数等等。在 这种情况下, order by 是可选的。

归类序列

利用 order by,可以将空值排在其它所有值之前。

• Adaptive Server 上的排序顺序 (归类序列)决定了数据的排序顺 序。排序顺序可以选择二进制、字典、不区分大小写、具有优先级 的区分大小写以及不区分大小写和变音。还可以提供特定于本国/地 区语言的排序顺序。

1-27: 排序顺序选择的影响

image

Adaptive Server 排序顺序 对 order by 结果的影响

二进制顺序 根据字符集中每个字符的字节数字值对所有数据进行排序。二进制排序 顺序将所有大写字母排在小写字母之前。二进制排序顺序是多字节字符 集的唯一选项。

字典顺序 将大写字母排在相应的小写字母之前 (区分大小写)。字典排序顺序识 别字母的各种变音形式,并将它们排在非变音形式之后。

字典顺序,不区分大小写 按字典顺序排序数据但不区分大小写。大写字母与对应的小写字母等

效,其排序方式如 接下来的 “排序规则”中所述。

字典顺序,不区分大小写,具 有优先级

将大写字母排在优先的位置,放在其相应小写字母之前。执行比较时

(例如在 where 子句中)不区分大小写。

字典顺序, 不区分大小写和变音 按字典顺序对数据排序,但不区分大小写;将变音格式的字母与相关联

的未变音字母同等对待。此排序顺序在排序结果中混合变音字符和非变 音字符。


sp_helpsort 报告 Adaptive Server 上安装的排序顺序。


排序规则

当按 Adaptive Server 的排序顺序有两行等值时,将使用以下规则对行进 行排序:

比较在 order by 子句中指定的列中的值。

如果两行有相等的列值,则逐字节比较整行的二进制值。该比较在 行上以列的内部排序顺序执行,而不是以列在查询或原始的 create table 子句中指定的顺序执行。简而言之,数据先按顺序存储在所有 固定长度列中,然后再按顺序存储在所有可变长度列中。

如果行相等,则比较行 ID。 给定表:

create table sortdemo (lname varchar (20),

init char (1) not null)

和数据:

lname init

---------- ----

Smith B

SMITH C

smith A

当按 lname 排序时得到结果如下:

lname init

---------- ----

smith A

Smith B

SMITH C

因为在内部首先存储固定长度的 char 数据 (init 列),所以 order by 基于 “Asmith”、“BSmith”和 “CSMITH”的二进制值对这些行 进行排序。

但是,如果 init varchar 类型,则首先排列 lname 列,然后再排列 init 列。对 “SMITHC”、“SmithB”和 “smithA”的二进制值进行 比较,且行以该顺序返回。

降序扫描

order by 子句中使用 desc 关键字为查询优化程序提供了一种不需 要工作表和排序步骤就能以降序返回结果的策略。此优化按每个索 引页上的前一页指针,反向扫描该索引的页链。


若要使用这种优化方式, order by 子句中的列必须与索引顺序相匹 配。这些列可以是键的子集,但必须是前缀子集,也就是说,它们 必须包括前面的键。如果在 order by 子句中指定的列是索引键的超 集,则不能使用降序扫描优化。

如果查询中涉及连接,则可以按降序的键顺序扫描所有表,只要满 足键的前缀子集要求即可。也可以将降序扫描优化用于连接中的一 个或多个表,而其它表仍按升序顺序进行扫描。

如果其它用户进程正向前扫描以执行更新或删除操作,执行降序扫 描可能导致死锁。在执行页面拆分和收缩时也可能遇到死锁。可以 在服务器上使用 sp_sysmon 跟踪死锁,或者使用配置参数 print deadlock information 将死锁信息发送到错误日志。

如果应用程序必须以降序顺序返回结果,但降序扫描优化产生了死 锁问题,则可能的解决方法有:

对降序扫描使用 set transaction isolation level 0 扫描。有关隔离级 别 0 读取的效果的详细信息,请参见 set 命令以及 《性能和调 优指南:锁定》中的 “使用锁定命令”。

使用 allow backward scans 配置参数禁用降序扫描优化,以便使 用 desc 的所有查询都以升序顺序扫描表并以降序顺序对结果集 进行排序。请参见 《系统管理指南》。

将有问题的降序扫描分为两步:首先,按升序顺序将所需行选 入临时表;然后,按降序顺序从临时表中进行选择。

如果后向扫描由于重复键值的存在而使用了包含溢出页的聚簇索 引,则降序扫描所返回的结果集可能不与升序扫描所返回的结果集 的顺序完全相反。指定的键值按顺序返回,但溢出页上相同键的行 的顺序可能不同。有关聚簇索引中溢出页存储方式的说明,请参见

《性能和调优指南:基础知识》中的 “索引”。

标准 符合 ANSI SQL 的级别Transact-SQL 扩展。

使用 union 运算符时在 select 语句的 order by 子句中指定新的列标题是一 种 Transact-SQL 扩展。

存在相同的表列名和列别名时, order by 的行为是 ANSI SQL 标准的特定 于供应商的扩展。

另请参见 命令 compute clause, declare, group by having 子句 , select, where 子句 .

系统过程 sp_configure, sp_helpsort, sp_lock, sp_sysmon.




--------------------------------------华丽的分割线-------------------------------------------------------------------------
之前就已经研发成功了能够从Sybase SQL Anywhere的DB文件中恢复数据的工具:ReadASADB。
此工具支持ASA v5.0,v6.0,v7.0,v8.0,v9.0,v10.0,v11.0,v12.0等版本。
恢复Sybase SQL Anywhere的工具在国内应该算首创。

ReadASADB功能
能够从损坏的SQL Anywhere数据文件(.db)和UltraLite数据文件(.udb)上提取数据的非常规恢复工具

  1. 适用于所有的SQL Anywhere版本    包括:5.x,6.x,7.x,8.x,9.x,10.x,11.x,12.x
  2. 适用于所有的UltraLite版本
  3. 能够恢复出来表结构和数据
  4. 能够恢复自定义数据类型
  5. 能够恢复存储过程等对象的语法
  6. 能够导出到目标数据库
  7. 能够导出到SQL文件并生成导入脚本
  8. 支持多种字符集  包括:cp850、cp936、gb18030、utf8等
  9. 能够恢复未加密或者简单加密类型的数据
  10. 简单易用
  11. 限制:不支持AES加密的数据文件
请参考:研发成功了从Sybase SQL Anywhere的DB文件上恢复数据的工具
            SQL Anywhere数据库非常规恢复工具ReadASADB使用介绍

ReadASADB适用场景

各种误操作:

  1. 误截断表(truncate table)
  2. 误删除表(drop table)
  3. 错误的where条件误删数据
  4. 误删除db或log文件
  5. 误删除表中的字段

本工具的应用场景:

1.因为物理磁盘故障、操作系统、系统软件方面或者掉电等等原因导致的Sybase SQL Anywhere数据库无法打开的情况;
2.误操作,包括truncate table,drop table,不正确的where条件导致的误删除等;
Sybase SQL Anywhere无法打开时,比较常见的错误是:Assertion failed。
如:
1、Internal database error *** ERROR *** Assertion failed:201819 (8.0.1.2600) Checkpoint log: invalid bitmap page -- transaction rolled back
2、Internal database error *** ERROR *** Assertion failed:201819 (8.0.1.2600) Page number on page does not match page requested -- transaction rolled back
3、Internal database error *** ERROR *** Assertion failed:200502 (9.0.2.2451) Checksum failure on page 23 -- transaction rolled back
4、File is shorter than expected
5、Internal database error *** ERROR *** Assertion failed: 201116 Invalid free list index page found while processing checkpoint log -- transaction rolled back
6、*** ERROR *** Assertion failed: 51901 Page for requested record not a table page or record not present on page等等。
+-------------------------------------华丽的分割线-------------------------------------------------------------------------