db2 "create db testdb on /home/db2inst1/testdb using codeset UTF-8 territory US"
对于上面的创建数据库语句,其中codeset和territory这两个选项的值一旦在数据库创建完成后,就无法修改,如果要修改的话
只能通过db2move来操作了,先把数据导出,删除数据库,创建新的数据库再将数据导入即可
导出数据库里面已经存放的数据:
db2move rordb99 export
db2move rordb99 export -sn UATATM //只导出UATATM用户的表
导出数据库对象的DDL:
db2look -d testdb -e -a -x -o testdb.sql
删除数据库:
db2 drop db testdb
创建新的数据库:
db2 "create db testdb on /home/db2inst1/testdb using codeset GBK territory CN"
手动创建bufferpool和tablespace
以及更改数据库参数
创建数据库对象:
db2 -tvf testdb.sql
导入数据库数据:
db2move testdb load
检查日志,直至没有任何报错
Add 2010.01.27:
在做完上述动作之后,一切都很正常,但是应用程序却有很多问题,这个时候发现有些表的状态不对,处在pending state
这时需要对这些有问题的表做set integrity的动作,因为这个动作只能一个表一个表的做,针对单个表的命令如下:
db2 connect to rordb99 user uatcfg using uatcfg
db2 set integrity for ACTION_MASTER immediate checked
如果要对所有的用户表进行set integrity动作,比较笨的办法是把所有的表都查出来再用UltraEdit等工具来编辑好脚本,然后再执行脚本即可,比较聪明的办法如下:
db2 "select 'db2 set
integrity for oatest.'||TABNAME||' immediate checked' from syscat.tables where TABSCHEMA='MYSCHEMA' and
STATUS='C'"执行完脚本后,应用程序即正常了
这里因为表里面有很多constraint, 对表进行load后,需要check constraint 不然没法正常使用,更多信息可以参考下面这篇文章(很详细的数据库迁移方面的文章):
http://macrozeng.itpub.net/post/71/58248PS:
codeset是什么,territory是什么? 类似date, time, timestamp数据类型在数据库的存放及显示方式都属于territory的范畴
而codeset 则是数据在数据库里面的编码方式,同样的一个汉字当codeset为GBK或UTF-8时,其在数据库里面的存放是不一样的
阅读(2060) | 评论(0) | 转发(0) |