快速解决SYBASE编程中所遇到的莫名错误
日期:2007年8月2日 作者: 查看:[大字体 中字体 小字体]-
SYBASE 数据库是当今在UNIX环境下最为流行的大型数据库之一,本人在SYBASE下开发和维护软件的过程中,发现了一些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_2
select @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后有四个空格)。你可以加上如下两句来验证:
declare @val3 char(10)
select @val3 = @val_1 + @val_2
select @val3这时你会得到的结果为0000 x (在0000后有四个空格)
解决方法二:将char 改为 varchar 也可以达到预期的目的。
2、用alter table 增加表结构时,虽然用sp_recompile tablename 重编译了所影响的数据库对象,但在运行某些包含"select * from tablename"的存储过程时,存储进程仍不认识用alter table 增加的列。例:
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
aa bb cc
----------- ------------- -------------
12 1234 NULL为什么cc字段是NULL,而不是"abcdefg"? 用alter table 增加表结构后,包含"select * from tablename"的存储过程,用sp_recompile tablename 重编译仍不能使新增的列被存储过程所识别。解决办法只有一个:删掉后重建。
- [1] [2] 下一页
-
- 快速解决SYBASE编程中所遇到的莫名错误 相关文章:
- ·用Illustrator封套快速制作时装广告
- ·加快Windows Vista系统窗口打开速度的方法
- ·PPMate网络电视快速定位到指定频道的方法
- ·Windows系统快修技巧31招(下)
- ·VC资源更新器 让电驴更快一些
- ·Windows系统快修技巧
- ·Photoshop快速使你的手机照变鲜艳
- ·Photoshop批处理快速制作同尺寸图片
- ·缩短响应时间 让Windows Vista跑得更快
- ·Photoshop的动作快捷键排版制作证件照
- 快速解决SYBASE编程中所遇到的莫名错误 相关软件
- ·快乐成语连连看
- ·《血腥屠虫》爽快射击试玩
- ·《快打旋风3》模拟器
- ·《快打旋风合集》模拟器街机游戏
- ·《Hello Kitty快乐派对》GBA 模拟器
- ·《无厘头快快》1.09-1.10客户端补丁
- ·滑板快打
- ·快园道古
- ·都市人情感诊所:不快乐的人是笨猪
- ·司考快餐车
- 特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作
- 者.文章版权归文章原始作者所有.对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转
- 载的文章有版权问题请联系编辑人员,我们尽快予以更正. 转载请注明来源:http://www.hackhome.com
精品推荐
热点TOP10
- ·图象处理中的边缘检测------canny算子
- ·EZ-USB 68013A开发指南
- ·数值计算程序大放送-特征值和特征向量
- ·ARM的嵌入式Linux移植体验之BootLoader
- ·Visual C++ ADO数据库编程入门
- ·智能手机Smartphone开发导语
- ·利用 wordXP 实现自动排班
- ·[分形]DLA团簇模型的摸拟
- ·DENX U-Boot及Linux使用手册
- ·Visual FoxPro 9.0 SP2正式版下载
- ·VS2005控件的问题解决办法
- ·Cookie是什么?用法是怎样?与SESSION有什么区别?
- ·J2SE API读取Properties文件的六种方法
- ·Silverlight、JavaFX、Flex技术比较
- ·Silverlight将不再支持ArrayList类型
- ·教程:XSLT Designer快速入门指南
- ·创建Web应用和Struts框架配置文件实例
- ·Spring入门指引:理解Spring的打包方式
- ·UDT协议-基于UDP的可靠数据传输协议
- ·解析KJava在移动设备开发中的应用
