<iframe align="center" marginwidth="0" marginheight="0" src="http://www.zealware.com/csdnblog336280.html" frameborder="0" width="336" scrolling="no" height="280"></iframe>
SYBASE编程中的莫名错误及其解决办法
|
01-5-25 下午 03:13:29
|
SYBASE 数据库是当今在UNIX环境下最为流行的大型数据库之一,本人在SYBASE下开发和维护软件的过程中,发现了一些SYBASE的内部规则,在程序设计中极易造成误解,而达不到预期的目的。下文将本人所发现的几个问题及其解决办法叙述如下: |
1、在sybase11.5中,组合两个定长的 char(x)="aaa",char (y)="bbb"; char(x)+char(y)!="aaabbb" |
select @var_1= @val_1 + @val_2 |
我们期望的结果为0000x, 而实际上其结果为0000。 |
解决方法一:当我们将"select @var_1=@val_1+@val_2",改为"select @var_1=rtrim(@var_1)+@var_2"时,我们便看到了我们所期望的结果。为什么呢?在有的SYBASE版本中存储一个char(n)时,在其真实值后补上了相应数量的空格,在本例中,存储在@var_1中的是0000 (在0000后有四个空格)。你可以加上如下两句来验证: |
select @val3 = @val_1 + @val_2 |
这时你会得到的结果为0000 x (在0000后有四个空格) |
解决方法二:将char 改为 varchar 也可以达到预期的目的。 |
2、用alter table 增加表结构时,虽然用sp_recompile tablename 重编译了所影响的数据库对象,但在运行某些包含"select * from tablename"的存储过程时,存储进程仍不认识用alter table 增加的列。例: |
1> create table tmp(aa int,bb int) |
1> create table b_tmp(aa int,bb int) |
1> insert b_tmp select * from tmp |
1> alter table tmp add cc char(8) null |
1> alter table b_tmp add cc char(8) null |
1>insert tmp values(12,1234,"abcdefg") |
----------- ------------- ------------- |
为什么cc字段是NULL,而不是"abcdefg"? 用alter table 增加表结构后,包含"select * from tablename"的存储过程,用sp_recompile tablename 重编译仍不能使新增的列被存储过程所识别。解决办法只有一个:删了重建。 |
SYBASE编程中的莫名错误及其解决办法
|
01-5-25 下午 03:13:29
|
SYBASE 数据库是当今在UNIX环境下最为流行的大型数据库之一,本人在SYBASE下开发和维护软件的过程中,发现了一些SYBASE的内部规则,在程序设计中极易造成误解,而达不到预期的目的。下文将本人所发现的几个问题及其解决办法叙述如下: |
1、在sybase11.5中,组合两个定长的 char(x)="aaa",char (y)="bbb"; char(x)+char(y)!="aaabbb" |
select @var_1= @val_1 + @val_2 |
我们期望的结果为0000x, 而实际上其结果为0000。 |
解决方法一:当我们将"select @var_1=@val_1+@val_2",改为"select @var_1=rtrim(@var_1)+@var_2"时,我们便看到了我们所期望的结果。为什么呢?在有的SYBASE版本中存储一个char(n)时,在其真实值后补上了相应数量的空格,在本例中,存储在@var_1中的是0000 (在0000后有四个空格)。你可以加上如下两句来验证: |
select @val3 = @val_1 + @val_2 |
这时你会得到的结果为0000 x (在0000后有四个空格) |
解决方法二:将char 改为 varchar 也可以达到预期的目的。 |
2、用alter table 增加表结构时,虽然用sp_recompile tablename 重编译了所影响的数据库对象,但在运行某些包含"select * from tablename"的存储过程时,存储进程仍不认识用alter table 增加的列。例: |
1> create table tmp(aa int,bb int) |
1> create table b_tmp(aa int,bb int) |
1> insert b_tmp select * from tmp |
1> alter table tmp add cc char(8) null |
1> alter table b_tmp add cc char(8) null |
1>insert tmp values(12,1234,"abcdefg") |
----------- ------------- ------------- |
为什么cc字段是NULL,而不是"abcdefg"? 用alter table 增加表结构后,包含"select * from tablename"的存储过程,用sp_recompile tablename 重编译仍不能使新增的列被存储过程所识别。解决办法只有一个:删了重建。 |
分享到:
相关推荐
SYBASE 数据库是当今在UNIX环境下最为流行的大型数据库之一,作者在SYBASE下开发和维护软件的过程中,发现了一些SYBASE的内部规则,在程序设计中极易造成误解,...本文将作者所发现的几个问题及其解决办法和大家分享。
SYBASE数据库是当今在UNIX环境下最为流行的大型数据库之一,本人在SYBASE下开发和维护软件的过程中,发现了一些SYBASE的内部规则,在程序设计中极易造成误解,而达不到...本文介绍了SYBASE编程中几个问题及其解决办法。
这是一本中文sybase编程指南,内容涵盖嵌式SQL,JAVA等
Sybase安装步骤及中文乱码解决办法,本人参考各种资料,然后自己解决成功无数次后总结的结果
sybase 3414 错误解决方案 附带错误日志
asa 编程指南 pdf版本 中文版本
C#连接sybase查询数据时,出现中文乱码的完美解决办法。
sybase乱码解决办法,发布项目访问地址,中文都显示为乱码
sybase数据库无法删除解决办法 sybase数据库无法删除解决办法
sybase数据库错误信息手册,sybase数据库
sybase12.5.3 跨平台备份恢复 错误解决
sybase编程样例包含c,c++,java等 有嵌入式sql 的c编程 有sybase封装的 ADO.NET C DBTools ESQLDynamicLoad ESQLProc ESQLWideFetch ExternalProcedures HTTP JavaSQL ODBCConnect ODBCExecute ODBCPrepare ...
本指南参考了 SAP Sybase 错误代码 (第 1 页)和 SQL 预处理器错误 (第 3 页)。消息按错误编号进行组织,且包括与该消息关联的所有属性。
解决sybase数据库服务启动失败的方法
SYBASE15错误码查询,错误消息高级解决方案手册
错误消息按 Sybase 错误代码进行索引.........................................65 按消息内容顺序排列的错误消息列表........................................105 内部错误(断言失败).............................
c语言sybase数据库编程.pdf
c语言sybase数据库编程[文].pdf
Sybase数据库更换字符集方法,解决中文乱码问题