Sybase Central中代理数据库分类出错的问题解决

---------------------------------------------------------------------------

---- 本文为andkylee个人原创,请在尊重作者劳动成果的前提下进行转载;

---- 转载务必注明原始出 : http://blog.csdn.net/andkylee

--- 2010-07-02 15:18:00

---- 关键字: Sybase Central proxy database 代理表 代理数据库

----------------------------------------------------------------------------

问题描述:

在Sybase Central中查看数据库时,在数据库目录下没有找到某个用户数据库(名字:andkylee),但是用isql连上数据库执行sp_helpdb能够查询到andkylee的确存在。在Sybase Central中找了一会儿,竟然在代理数据库目录下找到了数据库andkylee。很是奇怪,怎么跑到代理数据库里面了。数据库andkylee就是一个普通的用户数据库而已。

继续,依次展开代理数据库里面的andkylee库的目录,却找不到任何的用户表。代理表目录空空的,也没有用户表目录(真正的代理数据库中没有用户表)。纳闷了,andkylee库里的用户表都跑到哪里去了?

不过,用其它的数据库客户端工具是能够查询到andkylee库里面的用户表数据的。比如:用isql连上数据库,进入到andkylee库里。sp_help可以查看到所有的对象名称。发现用户表都在,执行select能够查看到表的数据。其它的比如:powerbuilder,dbartisan里面都能够在tables目录下面找到andkylee库里的所有表。看来,用户数据库andkylee没多少异常。是普通库而不是代理数据库。

 

 

分析原因:

一开始,我以为是andkylee库里的用户没有关联上登陆账号引起的。这个情况是比较常见的。

在master库中执行:select suid ,name from syslogins where name='escourt4'

登录escourt4对应的suid为:5。

在进入到用户库andkylee里面。

可以看出库andkylee里面的用户escourt4的uid为:3,它的suid为:5,正是对应的登录escourt4的suid。这没有问题,是正常的!

 

这好像和用户数据库andkylee没多少关系了,到master库里面找找是什么原因!

先看master的系统表sysdatabases中都存储了关于每个数据库的什么信息?

sysdatabases中的各个字段的信息如下:

 

def_remote_loc存储着远程表的默认存储位置。

 

用Interactive SQL查看系统表sysdatabases的数据(不用PowerBuilder的原因是:查询结果中区分不了null和空串)。

仔细比较sysdatabases中各个数据库的信息。发现andkylee对应的ref_remote_loc值非null,而其它库对应的ref_remote_loc值都为null。

难道原因在这里?

 

解决办法:

将库andkylee在sysdatabases表中对应的ref_remote_loc的值改为:null。

用Sybase Central重新连接数据库。发现用户库andkylee已经不在代理数据库里面了。问题解决了!

 

 

此问题和sybase中的代理数据库有关。

那么试验一下ASE中的代理数据库吧!

 

目的:建立一个代理数据库proxydb,引用同一ASE上另外一个用户数据库andkylee的用户escourt4下所有对象。

 

初始化设备proxydb_dat,proxydb_log两个设备,并建立代理数据库proxydb。 在proxydb里面建立指向local.andkylee.escourt4.的所有对象的代理表。

 

 

查看代理数据库proxydb里面的代理表的数据:

 

代理数据库创建成功了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值