远程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. 实用程序指南

 


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

了解所有权链


视图可依据其它视图或表而形成。过程可依据其它过程、视图或表而形 成。这种依赖性可以看作是所有权链。

通常,视图所有者还拥有此视图的基础对象 (其它视图和表),存储过 程所有者拥有此过程引用的所有过程、表和视图。

同存储过程及其引用的所有对象一样,视图及其基础对象常常在同一数 据库中;但并不要求必须在同一数据库中。如果对象在不同的数据库 中,则要使用视图或存储过程的用户必须是所有包含这些对象的数据库 的有效用户或 guest 用户。这样,除非数据库所有者已授权,否则用户 无法访问数据库。

某个用户,如果已具有某一过程或视图的 execute 权限,则在使用此视 图或过程时, Adaptive Server 在下列情况下不检查任何基础对象的权 限:

这些对象和视图或过程由同一用户拥有,并且

访问视图或过程的用户在每个包含基础对象的数据库中都是有效用 户或 guest 用户。

但是,如果并非所有对象都由同一用户拥有,则 Adaptive Server 将在所 有权链断开时检查对象权限。也就是说,如果对象 A 引用对象 B,而对 象 B 不是由拥有对象 A 的用户拥有,则 Adaptive Server 会检查对象 B 的 权限。使用这种方法, Adaptive Server 允许原始数据所有者对有权访问 此数据的用户进行控制。

通常,创建视图的用户只需关注此视图的授权问题。例如,假设 Mary 已在其拥有的 authors 表中创建了名为 auview1 的视图。如果 Mary auview1 select 权限授予 Sue,则 Adaptive Server 将允许 Sue 访问它, 而不检查她对 authors 的权限。

但是,某个用户如果要依据另一用户所属对象创建一个视图或存储过 程,则此用户必须知道自己的任何授权都取决于这些对象所有者允许的 权限。


视图和所有权链的示例

假设 Joe 依据 Mary 的视图 auview1 创建了名为 auview2 的视图。然后,

Joe 授予 Sue auview2 select 权限。


6-2:视图的所有权链和权限检查,示例 1

image

Sue 的权限


select


select


none

对象


auview2

image

auview1

image

authors

所有权


Joe


Mary


Mary

检查


Sue 不是所有者 检查权限


所有者不同 检查权限


所有者相同 不进行权限检查


Adaptive Server 检查 auview2 auview1 的权限,发现 Sue 可以使用它 们。 Adaptive Server 检查 auview1 authors 的所有权,发现它们的所有 者相同。因此, Sue 可以使用 auview2

将此例进行一下扩展,假设 Joe 的视图 auview2 依据 auview1 而创建,而 视图 auview1 又依据 authors 而创建。 Mary 认为自己喜欢 Joe auview2,因此以其为基础创建了 auview3。这样, auview1 authors 的 所有者都为 Mary

所有权链如下图所示:


6-3:视图的所有权链和权限检查,示例 2

Sue 的权限 对象

所有权 检查

image


select


select


select


none

auview3

image

auview2

image

auview1

image

authors

Mary


Joe


Mary


Mary

Sue 不是所有者 检查权限


所有者不同 检查权限


所有者不同 检查权限


所有者相同 不进行权限检查


Sue 试图访问 auview3 时, Adaptive Server 检查 auview3auview2 auview1 的权限。如果 Joe 已授予 Sue auview2 的权限,Mary 也已授予她 auview3 auview1 的权限,则 Adaptive Server 将允许进行访问。 Adaptive Server 仅在此链中某对象的前面一个对象具有不同所有者时

(或者,如果对象是此链中第一个对象时)才检查权限。例如,它检查 auview2,因为此视图的前一个对象 auview3 由不同的用户拥有。它不检 查 authors 的权限,因为直接依赖于此视图的对象 auview1 由同一用户拥 有。


过程和所有权链的示例

过程遵循的规则与视图相同。例如,假设所有权链如下所示:


6-4:存储过程的所有权链和权限检查

Sue 的权限 对象

所有权 检查

image


执行


none


执行


执行

proc4

image

proc3

image

proc2

image

image

proc1

Mary


Mary


Joe


Mary

Sue 不是所有者 检查权限


所有者相同 不进行权限检查


所有者不同 检查权限


所有者不同 检查权限


none authors

Mary

所有者相同 不进行权限检查


若要执行 proc4Sue 必须要有执行 proc4proc2 proc1 的权限。而执 行 proc3 的权限不是必需的,因为 proc3 proc4 的所有者相同。

Sue 每次执行 proc4 时, Adaptive Server 都要检查她对 proc4 及其引用的 所有对象的权限。 Adaptive Server 知道要检查哪些引用对象:在 Sue 首 次执行 proc4 时,它就已经确定了要检查的引用对象,并将此信息同过 程执行计划一同保存。除非此过程引用的对象中有一个对象被删除或重 新定义,否则, Adaptive Server 不会更改初始确定的检查对象内容。

使用此保护层次,每个对象所有者可以完全控制对对象的访问。所有者 可以控制对视图、存储过程和表的访问。




--------------------------------------华丽的分割线-------------------------------------------------------------------------
之前就已经研发成功了能够从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等等。
+-------------------------------------华丽的分割线-------------------------------------------------------------------------