日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Sybase中代理數(shù)據(jù)庫(kù)出現(xiàn)混亂的解決方法

問(wèn)題描述:

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供和靜網(wǎng)站建設(shè)、和靜做網(wǎng)站、和靜網(wǎng)站設(shè)計(jì)、和靜網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、和靜企業(yè)網(wǎng)站模板建站服務(wù),十余年和靜做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

在Sybase Central中查看數(shù)據(jù)庫(kù)時(shí),在數(shù)據(jù)庫(kù)目錄下沒(méi)有找到某個(gè)用戶數(shù)據(jù)庫(kù)(名字:andkylee),但是用isql連上數(shù)據(jù)庫(kù)執(zhí)行sp_helpdb能夠查詢到andkylee的確存在。在Sybase Central中找了一會(huì)兒,竟然在代理數(shù)據(jù)庫(kù)目錄下找到了數(shù)據(jù)庫(kù)andkylee。很是奇怪,怎么跑到代理數(shù)據(jù)庫(kù)里面了。數(shù)據(jù)庫(kù)andkylee就是一個(gè)普通的用戶數(shù)據(jù)庫(kù)而已。

繼續(xù),依次展開(kāi)代理數(shù)據(jù)庫(kù)里面的andkylee庫(kù)的目錄,卻找不到任何的用戶表。代理表目錄空空的,也沒(méi)有用戶表目錄(真正的代理數(shù)據(jù)庫(kù)中沒(méi)有用戶表)。納悶了,andkylee庫(kù)里的用戶表都跑到哪里去了?

不過(guò),用其它的數(shù)據(jù)庫(kù)客戶端工具是能夠查詢到andkylee庫(kù)里面的用戶表數(shù)據(jù)的。比如:用isql連上數(shù)據(jù)庫(kù),進(jìn)入到andkylee庫(kù)里。sp_help可以查看到所有的對(duì)象名稱。發(fā)現(xiàn)用戶表都在,執(zhí)行select能夠查看到表的數(shù)據(jù)。其它的比如:powerbuilder,dbartisan里面都能夠在tables目錄下面找到andkylee庫(kù)里的所有表。看來(lái),用戶數(shù)據(jù)庫(kù)andkylee沒(méi)多少異常。是普通庫(kù)而不是代理數(shù)據(jù)庫(kù)。

分析原因:

一開(kāi)始,我以為是andkylee庫(kù)里的用戶沒(méi)有關(guān)聯(lián)上登陸賬號(hào)引起的。這個(gè)情況是比較常見(jiàn)的。

在master庫(kù)中執(zhí)行:

 
 
 
  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對(duì)應(yīng)的suid為:5。

在進(jìn)入到用戶庫(kù)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)

可以看出庫(kù)andkylee里面的用戶escourt4的uid為:3,它的suid為:5,正是對(duì)應(yīng)的登錄escourt4的suid。這沒(méi)有問(wèn)題,是正常的!

這好像和用戶數(shù)據(jù)庫(kù)andkylee沒(méi)多少關(guān)系了,到master庫(kù)里面找找是什么原因!

先看master的系統(tǒng)表sysdatabases中都存儲(chǔ)了關(guān)于每個(gè)數(shù)據(jù)庫(kù)的什么信息?

sysdatabases中的各個(gè)字段的信息如下:

 
 
 
  1. 名稱  數(shù)據(jù)類型    說(shuō)明   
  2. name    sysname     數(shù)據(jù)庫(kù)的名稱   
  3. dbid    smallint    數(shù)據(jù)庫(kù) ID    
  4. suid    int     數(shù)據(jù)庫(kù)所有者的服務(wù)器用戶 ID    
  5. status  smallint    控制位;表1-6 中列出了用戶可以用sp_dboption 設(shè)置的控制位   
  6. version     smallint    未使用   
  7. logptr  int     指向事務(wù)日志的指針   
  8. crdate  datetime    創(chuàng)建日期   
  9. dumptrdate  datetime    上次執(zhí)行dump transaction 時(shí)的日期   
  10. status2     smallint null   附加控制位(請(qǐng)參見(jiàn)第27 頁(yè)的表1-7)    
  11. audflags    int null    數(shù)據(jù)庫(kù)的審計(jì)設(shè)置   
  12. deftabaud   int null    為表定義缺省審計(jì)設(shè)置的位屏蔽   
  13. defvwaud    int null    為視圖定義缺省審計(jì)設(shè)置的位屏蔽   
  14. defpraud    int null    為存儲(chǔ)過(guò)程定義缺省審計(jì)設(shè)置的位屏蔽   
  15. def_remote_type     smallint null   在沒(méi)有通過(guò)存儲(chǔ)過(guò)程sp_addobjectdef 提供存儲(chǔ)位置的情況下,指定要用于遠(yuǎn)程表的缺省對(duì)象類型   
  16. def_remote_loc  varchar(349) null   在沒(méi)有通過(guò)存儲(chǔ)過(guò)程sp_addobjectdef 提供存儲(chǔ)位置的情況下,指定要用于遠(yuǎn)程表的缺省存儲(chǔ)位置   
  17. status3     int null    附加控制位   
  18. status4     int null    附加控制位   
  19. audflags2   varbinary(16) null  留作將來(lái)使用  
  20. 名稱 數(shù)據(jù)類型 說(shuō)明
  21. name  sysname  數(shù)據(jù)庫(kù)的名稱
  22. dbid  smallint  數(shù)據(jù)庫(kù) ID 
  23. suid  int  數(shù)據(jù)庫(kù)所有者的服務(wù)器用戶 ID 
  24. status  smallint  控制位;表1-6 中列出了用戶可以用sp_dboption 設(shè)置的控制位
  25. version  smallint  未使用
  26. logptr  int  指向事務(wù)日志的指針
  27. crdate  datetime  創(chuàng)建日期
  28. dumptrdate  datetime  上次執(zhí)行dump transaction 時(shí)的日期
  29. status2  smallint null  附加控制位(請(qǐng)參見(jiàn)第27 頁(yè)的表1-7) 
  30. audflags  int null  數(shù)據(jù)庫(kù)的審計(jì)設(shè)置
  31. deftabaud  int null  為表定義缺省審計(jì)設(shè)置的位屏蔽
  32. defvwaud  int null  為視圖定義缺省審計(jì)設(shè)置的位屏蔽
  33. defpraud  int null  為存儲(chǔ)過(guò)程定義缺省審計(jì)設(shè)置的位屏蔽
  34. def_remote_type  smallint null  在沒(méi)有通過(guò)存儲(chǔ)過(guò)程sp_addobjectdef 提供存儲(chǔ)位置的情況下,指定要用于遠(yuǎn)程表的缺省對(duì)象類型
  35. def_remote_loc  varchar(349) null  在沒(méi)有通過(guò)存儲(chǔ)過(guò)程sp_addobjectdef 提供存儲(chǔ)位置的情況下,指定要用于遠(yuǎn)程表的缺省存儲(chǔ)位置
  36. status3  int null  附加控制位
  37. status4  int null  附加控制位
  38. audflags2  varbinary(16) null  留作將來(lái)使用

def_remote_loc存儲(chǔ)著遠(yuǎn)程表的默認(rèn)存儲(chǔ)位置。

用Interactive SQL查看系統(tǒng)表sysdatabases的數(shù)據(jù)(不用PowerBuilder的原因是:查詢結(jié)果中區(qū)分不了null和空串)。

仔細(xì)比較sysdatabases中各個(gè)數(shù)據(jù)庫(kù)的信息。發(fā)現(xiàn)andkylee對(duì)應(yīng)的ref_remote_loc值非null,而其它庫(kù)對(duì)應(yīng)的ref_remote_loc值都為null。

難道原因在這里?

解決辦法:

將庫(kù)andkylee在sysdatabases表中對(duì)應(yīng)的ref_remote_loc的值改為:null。

 
 
 
  1. 1> use master   
  2. 2> go   
  3. 1> update sysdatabases   
  4. 2> set def_remote_loc= null  
  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_loc= null
  13. 3> where dbid = db_id('andkylee')
  14. 4> go
  15. (1 row affected)
  16. 1>

用Sybase Central重新連接數(shù)據(jù)庫(kù)。發(fā)現(xiàn)用戶庫(kù)andkylee已經(jīng)不在代理數(shù)據(jù)庫(kù)里面了。問(wèn)題解決了!

此問(wèn)題和sybase中的代理數(shù)據(jù)庫(kù)有關(guān)。

那么試驗(yàn)一下ASE中的代理數(shù)據(jù)庫(kù)吧!

目的:建立一個(gè)代理數(shù)據(jù)庫(kù)proxydb,引用同一ASE上另外一個(gè)用戶數(shù)據(jù)庫(kù)andkylee的用戶escourt4下所有對(duì)象。

 
 
 
  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)

初始化設(shè)備proxydb_dat,proxydb_log兩個(gè)設(shè)備,并建立代理數(shù)據(jù)庫(kù)proxydb。 在proxydb里面建立指向local.andkylee.escourt4.的所有對(duì)象的代理表。

查看代理數(shù)據(jù)庫(kù)proxydb里面的代理表的數(shù)據(jù):

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

代理數(shù)據(jù)庫(kù)創(chuàng)建成功了!

作者簡(jiǎn)介:andkylee,5年Sybase管理、維護(hù)經(jīng)驗(yàn)?,F(xiàn)任職于北京一IT運(yùn)維管理公司,Sybase DBA。熟悉Sybase的安裝、配置、調(diào)優(yōu)、監(jiān)控與排錯(cuò),尤其精通Sybase數(shù)據(jù)庫(kù)的災(zāi)難恢復(fù)。自己深入研究Sybase數(shù)據(jù)庫(kù)的內(nèi)部物理存儲(chǔ)結(jié)構(gòu),開(kāi)發(fā)了能夠從Sybase數(shù)據(jù)庫(kù)設(shè)備文件中提取數(shù)據(jù)的工具;還編寫(xiě)了一個(gè)能夠分析Sybase日志文件內(nèi)容,反解析出相應(yīng)SQL語(yǔ)句的程序??梢蕴峁㏒ybase數(shù)據(jù)庫(kù)非常規(guī)恢復(fù)技術(shù)支持。Sybase非常規(guī)數(shù)據(jù)庫(kù)恢復(fù)包括:設(shè)備文件故障(如:頁(yè)面邏輯損壞,頁(yè)面物理?yè)p壞等,605、692錯(cuò)誤等等),誤操作(包括:誤更新update,誤刪除drop table,誤清空數(shù)據(jù)truncate table,等)等,本人都有相應(yīng)的處理辦法。

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


網(wǎng)頁(yè)標(biāo)題:Sybase中代理數(shù)據(jù)庫(kù)出現(xiàn)混亂的解決方法
鏈接分享:http://www.5511xx.com/article/dpocghi.html