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

 


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

print

说明 在用户屏幕上输出用户定义的消息。

语法 print

{format_string | @local_variable |

@@ global_variable} [, arg_list]

参数 format_string

可以是一个变量或字符串。 format_string 的最大长度是 1023 字节。

格式字符串最多可包含 20 个任意顺序的唯一占位符。将消息文本发 送到客户端时,使用 format_string 后接参数的格式化内容替换这些占 位符。

为了在用其它语法结构将格式字符串转换为某种语言时可以对参数重新 排序,要对占位符进行编号。参数所用占位符的显示形式如下:

%nn !”一个百分号 (%),后接一个 1 20 之间的整数,后面再接一个 感叹号 (!)。整数表示参数列表中字符串中的参数编号。“%1!”“%1!” 是原始版本中的第一个参数,“%2!”是第二个参数,依此类推。

用这种方法指示参数的位置可以使转换正确,即使参数出现在目标语 言中的顺序与其在原始语言中的顺序不同也是如此。

例如,假定以下是一条英文消息:

%1! is not allowed in %2!.

此消息的德语版本是:

%1! ist in %2!

此消息的日语版本是:


image


在此示例中,“ %1!”在所有三种语言中都表示同一参数,“%2!”也 是如此。此示例显示了翻译格式中有时需要对参数重新排序。

@local_variable

必须是 charncharvarchar nvarchar 类型,且必须在使用它的批处 理或过程中予以声明。

@@global_variable

必须是 char varchar 类型或可以自动转换成这些类型的类型 (例如

@@version )。当前, @@version 是唯一的字符类型的全局变量。


arg_list

可以是一系列由逗号分隔的变量或常量。arg_list 是可选的,除非提供 了包含 “%nn !”形式的格式字符串。在这种情况下, arg_list 所包含 的参数数目必须至少等于占位符的最大编号。参数可以是除 text image 以外的任何数据类型;在出现在最终的消息中之前,它将被转 换为字符数据类型。

示例 示例 1 如果在 authors 表中有住在邮政区号 94705 的作者,则输出 “Berkeley author”:

if exists (select postalcode from authors where postalcode = '94705')

print "Berkeley author"

示例 2 声明一个变量,为该变量赋值,然后输出变量值:

declare @msg char (50)

select @msg = "What's up, doc?" print @msg

What's up, doc?

示例 3 说明变量和占位符在消息中的用法:

declare @tabname varchar (30) select @tabname = "titles"


declare @username varchar (30) select @username = "ezekiel"


print "The table '%1!'is not owned by the user '%2!'.",

@tabname, @username

The table 'titles' is not owned by the user 'ezekiel.'

用法 替换后, format_string 加上所有参数的最大输出字符串长度是

1023 个字节。

如果在格式字符串中使用占位符,请记住:对于字符串中的每个占 位符 n,占位符 1 n- 1 也必须存在于同一字符串中,不过它们不 必以数值顺序出现。例如,不允许将占位符 1 3 放在一个格式字

符串中,却不把占位符 2 也放在此字符串中。如果在格式字符串中 省略了一个数字,则执行 print 时会生成错误消息。

arg_list 必须为 format_string 中的每个占位符各包括一个参数,否则 事务将被中止。可以使用比占位符多的参数。


要在错误消息中包括实际的百分号,请在 format_string 中使用两个 百分号 (“%%”)。如果 format_string 中包括不是用作占位符的单 个百分号 (“%”), Adaptive Server 将返回错误消息。

如果参数求值结果为 NULL,它将被转换成零长度的字符串。如果 不希望输出中出现零长度字符串,可使用 isnull 函数。例如,如果

@ arg 为空,下列语句将输出 I think we have nothing here.

declare @arg varchar (30)

select @arg = isnull (col1, "nothing") from table_a where ...

print "I think we have %1! here", @arg

可以将用户定义的消息添加到系统表 sysusermessages 中供所有应用 程序使用。使用 sp_addmessage sysusermessages 中添加消息;使 用 sp_getmessage 检索消息以供 print raiserror 使用。

使用 raiserror (而不是 print)输出用户定义的错误消息并将错误号 存储在 @@ error 中。

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

权限 使用 print 无需任何权限。

另请参见 命令 declare, raiserror.

系统过程 sp_addmessage, sp_getmessage.




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