Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > SYBASE编程中的莫名错误及其解决办法
【标  题】:SYBASE编程中的莫名错误及其解决办法
【关键字】:SYBASE
【来  源】:http://blog.chinaunix.net/article.php?articleId=56185&blogId=9609

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

Your Ad Here

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 重编译仍不能使新增的列被存储过程所识别。解决办法只有一个:删了重建。

install sybase for solaris10:【上一篇】
细说SYBASE数据库日志:【下一篇】
【相关文章】
  • install sybase for solaris10
  • SYBASE 11.5数据库安装维护基本手册
  • Sybase收购Avaki
  • Sybase的力作“企鹅宝典”(集成化Linux企业级数据库服务器)
  • Sybase EAServer补丁下载
  • Sybase欲收购Extended系统公司
  • Sybase ASE远程备份服务器的配置
  • 今晚被SYBASE拖到22:30才下班!
  • solaris安装sybase
  • SYBASE 补丁 安装指南
  • 【随机文章】
  • linux操作基础
  • ThinkPad T60现重大缺陷!主板居然飞线(ZT-WWW.INTOZGC.COM)
  • 监测站点使用多少session和application的程序
  • 进入Flash MX组件时代之六 改善组件用户体验
  • 通过chroot 构建Linux操作系统概要
  • 关于释放session的两篇文章(一)
  • 游戏进阶之千里之行始于足下(二)
  • 笔记:内核中的互斥
  • 让自己的程序支持CD刻录功能
  • HTML组件(HTML COMPONENTS)之三
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 bbb软讯网络 All Rigths Reserved.