Thursday, April 11, 2013

db2 联邦数据库练习


当我们需要对同一实例上两个数据库进行连接查询的时候是无法直接进行的。这一点在SQLServer中做得很好,可以直接使用数据库名称引用。而db2中必须使用联邦数据库(FEDERATED)
同一服务器上的两个实例:db2inst1 db2inst2 数据库分别是:mydb1 mydb2 (本地联邦和远程联邦同理,所以这里只演示远程联邦)
下面的操作在db2inst1上对db2inst2进行联邦,也就是可以在db2inst1上通过nickname访问db2inst2,所有操作都是在db2inst1下进行:

db2 update dbm cfg using FEDERATED YES
db2 connect to mydb1
--这里需要注意的是这个语句不能使用db2 ""执行,而是需要进入到db2 Command Line Processor 交互模式。这点是进行了很多尝试才发现的问题,注意问题是在password后面的字符串必须是双引号
--drda是默认的适配器
db2
create server f_mydb2 type db2/udb version 9.7 wrapper drda authorization db2inst2 password "******" options(dbname 'mydb2')
db2 "create user mapping for "db2inst1" server f_mydb2 options (add remote_authid 'db2inst2' , add remote_password '******')"
--db2inst2中存在一个表tb2
db2 "create nickname mydb2_tb2 for f_mydb2.db2inst2.tb2"
db2 "select * from mydb2_tb2"
db2 "select * from tb1 a inner join mydb2_tb2 b on b.id = a.id"

上面配置中需要注意的:

  1. 如果没有适配器可以使用Craete Wrapper创建一个适配器,如:Create wrapper drda 采用默认lib创建db2的适配器
  2. 因为语法原因,create server语句可能会需要在db2下执行,而不能以db2 ""方式执行
  3. create nickname时一定要记得必须在user mapping的用户下创建,否则无效



另外附上相关的表和视图:
SYSIBM.SYSWRAPPERS --每一行代表注册过的转换器 (wrapper) 
SYSIBM.SYSSERVERS  --每一行代表了数据源的信息,如数据源版本号,类型等
SYSIBM.SYSFUNCMAPPINGS   --包括函数映射的基本信息如函数映射名,基于服务器的名字等等,一般可以用来判断找不到相应函数这类的错误
SYSIBM.SYSSERVEROPTIONS   --包括对服务器选项的设置信息,如 Collating_sequence,PROXY_AUTHID 等,这些选项的设置可以对查询性能产生影响
SYSIBM.SYSTYPEMAPPINGS   --包括数据类型映射的基本信息,如联邦服务器这一侧的数据类型和远程数据源短的数据类型的对应关系,一般用于判断数据类型相关的错误
SYSIBM.SYSUSEROPTIONS   --在这个表中包括了用户选项及其设置值,如连接远程数据源使用的用户名和密码信息 (REMOTE_AUTHID, REMOTE_PASSWORD) 等,一般可以用于判断连接错误或者访问权限错误 ( 配合 DB2 本身的 SYSDBAUTH 系统表 ) 
SYSIBM.SYSWRAPOPTIONS   --其中包含了关于创建的转换器的一些可选信息,例如在使用转换器的时候是否使用“ Trusted ”或者“ Fenced ”选项
SYSIBM.SYSPASSTHRUAUTH
SYSIBM.SYSFUNCMAPPARMOPTIONS
SYSIBM.SYSFUNCMAPOPTIONS

视图:
SYSCAT.FUNCMAPPINGS 
SYSCAT.FUNCMAPPARMOPTIONS 
SYSCAT.FUNCMAPOPTIONS 
SYSCAT.NICKNAMES 
SYSCAT.PASSTHRUAUTH 
SYSCAT.SERVEROPTIONS 
SYSCAT.SERVERS 
SYSCAT.TYPEMAPPINGS 
SYSCAT.USEROPTIONS 
SYSCAT.ROUTINESFEDERATED








No comments:

Post a Comment