十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
问题描述:

成都创新互联专业为企业提供和静网站建设、和静做网站、和静网站设计、和静网站制作等企业网站建设、网页设计与制作、和静企业网站模板建站服务,十余年和静做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
在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'
 
- 1> select suid ,name from syslogins where name='escourt4'
 - 2> go
 - suid name
 - ----------- ------------------------------
 - 5 escourt4
 - (1 row affected)
 - 1> select suid ,name from syslogins where name='escourt4'
 - 2> go
 - suid name
 - ----------- ------------------------------
 - 5 escourt4
 - (1 row affected)
 
登录escourt4对应的suid为:5。
在进入到用户库andkylee里面。
- 1> use andkylee
 - 2> go
 - 1> select suid,uid,name from sysusers where name='escourt4'
 - 2> go
 - suid uid name
 - ----------- ----------- ------------------------------
 - 5 3 escourt4
 - (1 row affected)
 - 1> use andkylee
 - 2> go
 - 1> select suid,uid,name from sysusers where name='escourt4'
 - 2> go
 - suid uid name
 - ----------- ----------- ------------------------------
 - 5 3 escourt4
 - (1 row affected)
 
可以看出库andkylee里面的用户escourt4的uid为:3,它的suid为:5,正是对应的登录escourt4的suid。这没有问题,是正常的!
这好像和用户数据库andkylee没多少关系了,到master库里面找找是什么原因!
先看master的系统表sysdatabases中都存储了关于每个数据库的什么信息?
sysdatabases中的各个字段的信息如下:
- 名称 数据类型 说明
 - name sysname 数据库的名称
 - dbid smallint 数据库 ID
 - suid int 数据库所有者的服务器用户 ID
 - status smallint 控制位;表1-6 中列出了用户可以用sp_dboption 设置的控制位
 - version smallint 未使用
 - logptr int 指向事务日志的指针
 - crdate datetime 创建日期
 - dumptrdate datetime 上次执行dump transaction 时的日期
 - status2 smallint null 附加控制位(请参见第27 页的表1-7)
 - audflags int null 数据库的审计设置
 - deftabaud int null 为表定义缺省审计设置的位屏蔽
 - defvwaud int null 为视图定义缺省审计设置的位屏蔽
 - defpraud int null 为存储过程定义缺省审计设置的位屏蔽
 - def_remote_type smallint null 在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省对象类型
 - def_remote_loc varchar(349) null 在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省存储位置
 - status3 int null 附加控制位
 - status4 int null 附加控制位
 - audflags2 varbinary(16) null 留作将来使用
 - 名称 数据类型 说明
 - name sysname 数据库的名称
 - dbid smallint 数据库 ID
 - suid int 数据库所有者的服务器用户 ID
 - status smallint 控制位;表1-6 中列出了用户可以用sp_dboption 设置的控制位
 - version smallint 未使用
 - logptr int 指向事务日志的指针
 - crdate datetime 创建日期
 - dumptrdate datetime 上次执行dump transaction 时的日期
 - status2 smallint null 附加控制位(请参见第27 页的表1-7)
 - audflags int null 数据库的审计设置
 - deftabaud int null 为表定义缺省审计设置的位屏蔽
 - defvwaud int null 为视图定义缺省审计设置的位屏蔽
 - defpraud int null 为存储过程定义缺省审计设置的位屏蔽
 - def_remote_type smallint null 在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省对象类型
 - def_remote_loc varchar(349) null 在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省存储位置
 - status3 int null 附加控制位
 - status4 int null 附加控制位
 - audflags2 varbinary(16) null 留作将来使用
 
def_remote_loc存储着远程表的默认存储位置。
用Interactive SQL查看系统表sysdatabases的数据(不用PowerBuilder的原因是:查询结果中区分不了null和空串)。
仔细比较sysdatabases中各个数据库的信息。发现andkylee对应的ref_remote_loc值非null,而其它库对应的ref_remote_loc值都为null。
难道原因在这里?
解决办法:
将库andkylee在sysdatabases表中对应的ref_remote_loc的值改为:null。
- 1> use master
 - 2> go
 - 1> update sysdatabases
 - 2> set def_remote_loc= null
 - 3> where dbid = db_id('andkylee')
 - 4> go
 - (1 row affected)
 - 1>
 - 1> use master
 - 2> go
 - 1> update sysdatabases
 - 2> set def_remote_loc= null
 - 3> where dbid = db_id('andkylee')
 - 4> go
 - (1 row affected)
 - 1>
 
用Sybase Central重新连接数据库。发现用户库andkylee已经不在代理数据库里面了。问题解决了!
此问题和sybase中的代理数据库有关。
那么试验一下ASE中的代理数据库吧!
目的:建立一个代理数据库proxydb,引用同一ASE上另外一个用户数据库andkylee的用户escourt4下所有对象。
- 1> disk init
 - 2> name='proxydb_dat',
 - 3> physname='d:\syb_data\proxydb_dat.dat',
 - 4> size='20m'
 - 5> go
 - 1> disk init
 - 2> name='proxydb_log',
 - 3> physname='d:\syb_data\proxydb_log.dat',
 - 4> size='10m'
 - 5> go
 - 1> create database proxydb
 - 2> on proxydb_dat='20m' log on proxydb_log='10m'
 - 3> with default_location "local.andkylee.escourt4."
 - 4> for proxy_update
 - 5> go
 
- CREATE DATABASE: allocating 5120 logical pages (20.0 megabytes) on disk
 - 'proxydb_dat'.
 - CREATE DATABASE: allocating 2560 logical pages (10.0 megabytes) on disk
 - 'proxydb_log'.
 - Database 'proxydb' is now online.
 - New user added.
 - (1 row affected)
 - 1> disk init
 - 2> name='proxydb_dat',
 - 3> physname='d:\syb_data\proxydb_dat.dat',
 - 4> size='20m'
 - 5> go
 - 1> disk init
 - 2> name='proxydb_log',
 - 3> physname='d:\syb_data\proxydb_log.dat',
 - 4> size='10m'
 - 5> go
 - 1> create database proxydb
 - 2> on proxydb_dat='20m' log on proxydb_log='10m'
 - 3> with default_location "local.andkylee.escourt4."
 - 4> for proxy_update
 - 5> go
 - CREATE DATABASE: allocating 5120 logical pages (20.0 megabytes) on disk
 - 'proxydb_dat'.
 - CREATE DATABASE: allocating 2560 logical pages (10.0 megabytes) on disk
 - 'proxydb_log'.
 - Database 'proxydb' is now online.
 - New user added.
 - (1 row affected)
 
初始化设备proxydb_dat,proxydb_log两个设备,并建立代理数据库proxydb。 在proxydb里面建立指向local.andkylee.escourt4.的所有对象的代理表。
查看代理数据库proxydb里面的代理表的数据:
- 1> use proxydb
 - 2> go
 - 1> select top 10 id,name,user_name(uid) as user_name from proxydb..sysobjects
 - 2> where type='U'
 - 3> order by name
 - 4> go
 - id name
 - ----------- ----------------------------------------------------------------------------------
 - 800002850 AIX_PAGENOS
 - 832002964 AIX_PAGENO_RANGE
 - 864003078 AIX_SYS_syscolumns
 - 896003192 AIX_SYS_sysindexes
 - 928003306 AIX_SYS_sysobjects
 - 960003420 AJDACG
 - 992003534 AJDAJY
 - 1024003648 AJGDB
 - 1104003933 AJGDB1
 - 1168004161 AJGDB_BAKUP
 - (10 rows affected)
 - 1> select count(*) from escourt4.AJGDB1
 - 2> GO
 - -----------
 - 123611
 - (1 row affected)
 - 1> use proxydb
 - 2> go
 - 1> select top 10 id,name,user_name(uid) as user_name from proxydb..sysobjects
 - 2> where type='U'
 - 3> order by name
 - 4> go
 - id name
 - ----------- ----------------------------------------------------------------------------------
 - 800002850 AIX_PAGENOS
 - 832002964 AIX_PAGENO_RANGE
 - 864003078 AIX_SYS_syscolumns
 - 896003192 AIX_SYS_sysindexes
 - 928003306 AIX_SYS_sysobjects
 - 960003420 AJDACG
 - 992003534 AJDAJY
 - 1024003648 AJGDB
 - 1104003933 AJGDB1
 - 1168004161 AJGDB_BAKUP
 - (10 rows affected)
 - 1> select count(*) from escourt4.AJGDB1
 - 2> GO
 - -----------
 - 123611
 - (1 row affected)
 
代理数据库创建成功了!
作者简介:andkylee,5年Sybase管理、维护经验。现任职于北京一IT运维管理公司,Sybase DBA。熟悉Sybase的安装、配置、调优、监控与排错,尤其精通Sybase数据库的灾难恢复。自己深入研究Sybase数据库的内部物理存储结构,开发了能够从Sybase数据库设备文件中提取数据的工具;还编写了一个能够分析Sybase日志文件内容,反解析出相应SQL语句的程序。可以提供Sybase数据库非常规恢复技术支持。Sybase非常规数据库恢复包括:设备文件故障(如:页面逻辑损坏,页面物理损坏等,605、692错误等等),误操作(包括:误更新update,误删除drop table,误清空数据truncate table,等)等,本人都有相应的处理办法。
链接:http://blog.csdn.net/andkylee/archive/2010/07/02/5709340.aspx