sybase:SYBASE编程中的莫名错误及其解决办法



SYBASE编程中莫名及其解决办法


01-5-25 下午 03:13:29


SYBASE 数据库是当今在UNIX环境下最为流行大型数据库的本人在SYBASE下开发和维护软件Software过程中发现了些SYBASE内部规则设计中极易造成误解而达不到预期下文将本人所发现几个问题及其解决办法叙述如下:1、在sybase11.5中组合两个定长 char(x)=\"aaa\",char (y)=\"bbb\"; char(x)+char(y)!=\"aaabbb\" declare @val_1 char(8)declare @val_2 char(1)select @val_2 = \'x\'select @val_1 = \"0000\"select @var_1= @val_1 + @val_2select @var_1我们期望结果为0000x 而实际上其结果为0000解决思路方法:当我们将\"select @var_1=@val_1+@val_2\"改为\"select @var_1=rtrim(@var_1)+@var_2\"时我们便看到了我们所期望结果为什么呢?在有SYBASE版本中存储个char(n)时在其真实值后补上了相应数量空格在本例中存储在@var_1中是0000    (在0000后有 4个空格)你可以加上如下两句来验证:declare @val3 char(10)select @val3 = @val_1 + @val_2select @val3这时你会得到结果为0000    x (在0000后有 4个空格) 解决思路方法 2:将char 改为 varchar 也可以达到预期2、用alter table 增加表结构时虽然用sp_recompile tablename 重编译了所影响数据库对象但在运行某些包含\"select * from tablename\"存储过程时存储进程仍不认识用alter table 增加例:1> create table tmp(aa ,bb )2> go1> create table b_tmp(aa ,bb )2>go1> create proc tmpstore2> as 1> insert b_tmp select * from tmp2> 3> go1> alter table tmp add cc char(8) null2> go1> alter table b_tmp add cc char(8) null2> go1> sp_recompile tmp2> go1>insert tmp values(12,1234,\"abcdefg\")2>go1> exec tmpstore2> go1> select * from b_tmp2> goaabbcc----------- ------------- -------------121234NULL为什么cc字段是NULL,而不是\"abcdefg\"? 用alter table 增加表结构后包含\"select * from tablename\"存储过程用sp_recompile tablename 重编译仍不能使新增列被存储过程所识别解决办法只有个:删了重建
Tags:  sybaseiq sybasease sybase数据库 sybase

延伸阅读

最新评论

发表评论