|
Sybase程序设计中极易造成误解的内部规则
( 2008/6/20 09:41 )
SYBASE 数据库是当今在UNIX环境下最为流行的大型数据库之一,本人在SYBASE下开发和维护软件的过程中,发现了一些SYBASE的内部规则,在程序设计中极易造成误解,而达不到预期的目的。下文将本人所发现的几个问题及其解决办法叙述如下:
declare @val_1 char(8) declare @val_2 char(1) select @val_2 = 'x' select @val_1 = "0000" select @var_1= @val_1 + @val_2 select @var_1
我们期望的结果为0000x, 而实际上其结果为0000。
declare @val3 char(10) select @val3 = @val_1 + @val_2 select @val3
这时你会得到的结果为0000 x (在0000后有四个空格)。
1> create table tmp(aa int,bb int) 2> go 1> create table b_tmp(aa int,bb int) 2>go 1> create proc tmpstore 2> as 1> insert b_tmp select * from tmp 2> return 3> go 1> alter table tmp add cc char(8) null 2> go 1> alter table b_tmp add cc char(8) null 2> go 1> sp_recompile tmp 2> go 1>insert tmp values(12,1234,"abcdefg") 2>go 1> exec tmpstore 2> go 1> select * from b_tmp 2> go aabbcc ----------- ------------- ------------- 121234NULL
为什么cc字段是NULL,而不是"abcdefg"? 用alter table 增加表结构后,包含"select * from tablename"的存储过程,用sp_recompile tablename 重编译仍不能使新增的列被存储过程所识别。解决办法只有一个:删了重建。
|
·技巧实例:如何在.NET中访问MySQL数据库 (9-25) ·有关PB/Sybase开发过程中数据库转移介绍 (9-25) ·SQL Server 2008数据库中如何使用表值参数 (9-25) ·甲骨文推“数据库机器” 首涉电脑硬件销售 (9-25) ·入门级的ORACLE数据库备份与数据库还原 (9-24) 热议文章·宽带市场不宜“非对称管制” (9-21) 评:中国移动的庞大资金储备应该在TD上发挥应有的作用!!! ·重组后的中国联通,何以对抗即将到来的混战 (9-17) ·华为中高层缓发年终奖:或为备战电信招标 (8-27) ·现在部署WiMAX还是等待LTE? (8-26) ·专家呼吁出台《电信法》以制衡恶性博弈 (8-19) ·联通致力于成国际一流宽带通信信息服务运营商 (8-15) ·联通网通合并后名称暂定为联合网络通信公司 (8-14) ·技巧实例:如何在.NET中访问MySQL数据库 (9-25) ·资料分享:Java开发中该注意的一些东西 (9-25) ·移动智能网中No.7信令的应用 (9-25) ·马力克:电网建设超前 服务经济社会 (9-25) ·CDMA实体认证机制分析 (9-25) ·基于正交调制FSK/ASK光标记交换技术 (9-25) |
|||||||||||||||
|