Sybase中代理数据库出现混乱的解决方法

问题描述:

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

[[12558]]

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

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

分析原因:

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

在master库中执行:

  1. select suid ,name from syslogins where name='escourt4' 
  1. 1> select suid ,name from syslogins where name='escourt4'    
  2. 2> go     
  3.  suid        name     
  4.  ----------- ------------------------------     
  5.            5 escourt4     
  6. (1 row affected)    
  7. 1> select suid ,name from syslogins where name='escourt4' 
  8. 2> go  
  9.  suid        name  
  10.  ----------- ------------------------------  
  11.            5 escourt4  
  12. (1 row affected) 

 

登录escourt4对应的suid为:5。

在进入到用户库andkylee里面。

  1. 1> use andkylee     
  2. 2> go     
  3. 1> select suid,uid,name from sysusers where name='escourt4'    
  4. 2> go     
  5.  suid        uid         name     
  6.  ----------- ----------- ------------------------------     
  7.            5           3 escourt4     
  8. (1 row affected)    
  9. 1> use andkylee  
  10. 2> go  
  11. 1> select suid,uid,name from sysusers where name='escourt4' 
  12. 2> go  
  13.  suid        uid         name  
  14.  ----------- ----------- ------------------------------  
  15.            5           3 escourt4  
  16. (1 row affected) 

 

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

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

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

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

  1. 名称  数据类型    说明     
  2. name    sysname     数据库的名称     
  3. dbid    smallint    数据库 ID      
  4. suid    int     数据库所有者的服务器用户 ID      
  5. status  smallint    控制位;表1-6 中列出了用户可以用sp_dboption 设置的控制位     
  6. version     smallint    未使用     
  7. logptr  int     指向事务日志的指针     
  8. crdate  datetime    创建日期     
  9. dumptrdate  datetime    上次执行dump transaction 时的日期     
  10. status2     smallint null   附加控制位(请参见第27 页的表1-7)      
  11. audflags    int null    数据库的审计设置     
  12. deftabaud   int null    为表定义缺省审计设置的位屏蔽     
  13. defvwaud    int null    为视图定义缺省审计设置的位屏蔽     
  14. defpraud    int null    为存储过程定义缺省审计设置的位屏蔽     
  15. def_remote_type     smallint null   在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省对象类型     
  16. def_remote_loc  varchar(349) null   在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省存储位置     
  17. status3     int null    附加控制位     
  18. status4     int null    附加控制位     
  19. audflags2   varbinary(16) null  留作将来使用    
  20. 名称 数据类型 说明  
  21. name  sysname  数据库的名称  
  22. dbid  smallint  数据库 ID   
  23. suid  int  数据库所有者的服务器用户 ID   
  24. status  smallint  控制位;表1-6 中列出了用户可以用sp_dboption 设置的控制位  
  25. version  smallint  未使用  
  26. logptr  int  指向事务日志的指针  
  27. crdate  datetime  创建日期  
  28. dumptrdate  datetime  上次执行dump transaction 时的日期  
  29. status2  smallint null  附加控制位(请参见第27 页的表1-7)   
  30. audflags  int null  数据库的审计设置  
  31. deftabaud  int null  为表定义缺省审计设置的位屏蔽  
  32. defvwaud  int null  为视图定义缺省审计设置的位屏蔽  
  33. defpraud  int null  为存储过程定义缺省审计设置的位屏蔽  
  34. def_remote_type  smallint null  在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省对象类型  
  35. def_remote_loc  varchar(349) null  在没有通过存储过程sp_addobjectdef 提供存储位置的情况下,指定要用于远程表的缺省存储位置  
  36. status3  int null  附加控制位  
  37. status4  int null  附加控制位  
  38. 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. 1> use master     
  2. 2> go     
  3. 1> update sysdatabases     
  4. 2> set def_remote_locnull    
  5. 3> where dbid = db_id('andkylee')     
  6. 4> go     
  7. (1 row affected)     
  8. 1>    
  9. 1> use master  
  10. 2> go  
  11. 1> update sysdatabases  
  12. 2> set def_remote_locnull 
  13. 3> where dbid = db_id('andkylee')  
  14. 4> go  
  15. (1 row affected)  
  16. 1> 

 

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

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

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

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

  1. 1> disk init     
  2. 2> name='proxydb_dat',     
  3. 3> physname='d:\syb_data\proxydb_dat.dat',     
  4. 4> size='20m'    
  5. 5> go     
  6. 1> disk init     
  7. 2> name='proxydb_log',     
  8. 3> physname='d:\syb_data\proxydb_log.dat',     
  9. 4> size='10m'    
  10. 5> go     
  11. 1> create database proxydb     
  12. 2> on proxydb_dat='20m' log on proxydb_log='10m'    
  13. 3> with default_location "local.andkylee.escourt4."    
  14. 4> for proxy_update     
  15. 5> go    

 

  1. CREATE DATABASE: allocating 5120 logical pages (20.0 megabytes) on disk     
  2. 'proxydb_dat'.     
  3. CREATE DATABASE: allocating 2560 logical pages (10.0 megabytes) on disk     
  4. 'proxydb_log'.     
  5. Database 'proxydb' is now online.     
  6. New user added.     
  7. (1 row affected)    
  8. 1> disk init  
  9. 2> name='proxydb_dat',  
  10. 3> physname='d:\syb_data\proxydb_dat.dat',  
  11. 4> size='20m' 
  12. 5> go  
  13. 1> disk init  
  14. 2> name='proxydb_log',  
  15. 3> physname='d:\syb_data\proxydb_log.dat',  
  16. 4> size='10m' 
  17. 5> go  
  18. 1> create database proxydb  
  19. 2> on proxydb_dat='20m' log on proxydb_log='10m' 
  20. 3> with default_location "local.andkylee.escourt4." 
  21. 4> for proxy_update  
  22. 5> go  
  23. CREATE DATABASE: allocating 5120 logical pages (20.0 megabytes) on disk  
  24. 'proxydb_dat'.  
  25. CREATE DATABASE: allocating 2560 logical pages (10.0 megabytes) on disk  
  26. 'proxydb_log'.  
  27. Database 'proxydb' is now online.  
  28. New user added.  
  29. (1 row affected) 

 

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

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

  1.  
  2. 1> use proxydb     
  3. 2> go     
  4. 1> select top 10 id,name,user_name(uid) as user_name from proxydb..sysobjects     
  5. 2> where type='U'    
  6. 3> order by name     
  7. 4> go     
  8.  id          name     
  9.  ----------- ----------------------------------------------------------------------------------     
  10.    800002850 AIX_PAGENOS     
  11.    832002964 AIX_PAGENO_RANGE     
  12.    864003078 AIX_SYS_syscolumns     
  13.    896003192 AIX_SYS_sysindexes     
  14.    928003306 AIX_SYS_sysobjects     
  15.    960003420 AJDACG     
  16.    992003534 AJDAJY     
  17.   1024003648 AJGDB     
  18.   1104003933 AJGDB1     
  19.   1168004161 AJGDB_BAKUP     
  20. (10 rows affected)     
  21. 1> select count(*) from escourt4.AJGDB1     
  22. 2> GO     
  23.  -----------     
  24.       123611     
  25. (1 row affected)    
  26. 1> use proxydb  
  27. 2> go  
  28. 1> select top 10 id,name,user_name(uid) as user_name from proxydb..sysobjects  
  29. 2> where type='U' 
  30. 3> order by name 
  31. 4> go  
  32.  id          name 
  33.  ----------- ----------------------------------------------------------------------------------  
  34.    800002850 AIX_PAGENOS  
  35.    832002964 AIX_PAGENO_RANGE  
  36.    864003078 AIX_SYS_syscolumns  
  37.    896003192 AIX_SYS_sysindexes  
  38.    928003306 AIX_SYS_sysobjects  
  39.    960003420 AJDACG  
  40.    992003534 AJDAJY  
  41.   1024003648 AJGDB  
  42.   1104003933 AJGDB1  
  43.   1168004161 AJGDB_BAKUP  
  44. (10 rows affected)  
  45. 1> select count(*) from escourt4.AJGDB1  
  46. 2> GO  
  47.  -----------  
  48.       123611  
  49. (1 row affected) 

 

代理数据库创建成功了!

作者简介:andkylee,5年Sybase管理、维护经验。现任职于北京一IT运维管理公司,Sybase DBA。熟悉Sybase的安装、配置、调优、监控与排错,尤其精通Sybase数据库的灾难恢复。自己深入研究Sybase数据库的内部物理存储结构,开发了能够从Sybase数据库设备文件中提取数据的工具;还编写了一个能够分析Sybase日志文件内容,反解析出相应SQL语句的程序。可以提供Sybase数据库非常规恢复技术支持。Sybase非常规数据库恢复包括:设备文件故障(如:页面逻辑损坏,页面物理损坏等,605、692错误等等),误操作(包括:误更新update,误删除drop table,误清空数据truncate table,等)等,本人都有相应的处理办法。

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

链接:http://blog.csdn.net/andkylee/archive/2010/07/02/5709340.aspx

【编辑推荐】

  1. 活用Sybase超级用户密码
  2. Sybase数据库引擎运行方法简介
  3. Sybase数据备份之BCP用法简介
  4. Sybase数据库的几个配置问题
  5. 如何设置Sybase的用户权限来处理进程

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/232138.html<

(0)
运维的头像运维
上一篇2025-04-20 00:53
下一篇 2025-04-20 00:54

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注