表迁移后注意事项 【迁移与备份】
最近一些表空间满了,要把一些数据迁移到新的表空间去.所以写了以下文档,希望大家有帮助~
数据迁移注意事项
1、 函数注意事项
查看表中是否被其它函数使用,如果被其它函数使用,则在数据迁移之前,备份该函数语句,然后删除函数。数据迁移后重新生成函数;
1) 在db2look中查看被使用的函数名称
2) 使用SQL查看该表被哪一些函数使用
select funcname,SPECIFICNAME from syscat.FUNCTIONS where SPECIFICNAME in
(select dname from sysibm.sysdependencies where bname='T01_PUB_BANK' and FUNCSCHEMA='XDZX1')
2、 视图注意事项
查看表是否被其它视图使用,如果被其它视图使用。则在数据迁移之后,删除视图,然后重建;
1) 查看该表被哪一些视图使用
select * from syscat.TABDEP where bname='viewname' and DTYPE='V'
2) 查看该视图代码
select text from syscat.VIEWS where viewname=’viewname’
3) 获得数据库中非法视图
select viewschema, viewnamefrom syscat.views
where valid = 'x'
3、 物化视图注意事项
查看表是否被物化视图使用,如果被物化视图使用。则在数据迁移之后,重建物化视图;
1) 查看该表被哪一些物化视图使用
select * from syscat.TABDEP where bname='tabname' and DTYPE='S'
2) 查看该视图代码
select text from syscat.VIEWS where viewname=’viewname’
4、 存储过程注意事项
如果该表被存储过程调用则不影响数据迁移;
5、 删除函数,对存储过程的影响
在删除、重建函数后,必须对所有使用这个函数的存储过程进行重新编译。
找出存储过程未编译的存储过程,重新删除编译
select rtrim(a.ROUTINESCHEMA) ||'.'||rtrim(a.ROUTINENAME) procname,
'db2 "rebind package '||rtrim(a.ROUTINESCHEMA)||'.'||rtrim(b.PKGNAME)||' resolve any "' exec from
(select ROUTINESCHEMA,ROUTINENAME,'P'||SUBSTR(CHAR(lib_id+10000000),2) pkgname
from syscat.ROUTINES ) a,
(select PKGNAME from syscat.PACKAGES where pkgname not in(
select pkgname from syscat.PACKAGEDEP) and pkgschema='XDZX1') b
where a.PKGNAME = b.PKGNAME
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端