当前位置: 首页 > article >正文

【达梦数据库(Oracle模式)】如何将视图中的数据导出

在某些情况下,我们需要将生产环境某个模式下的数据导入到开发电脑中,因为正式环境无法连接外网数据。

方式一:将视图查询出来,然后右键导出所有查询结果(不推荐)

优点:方便快捷
缺点:视图如果很多的话,时间耗费就很久了

方式二:新建一个模式,将视图存到新模式的表中导出(推荐)

使用存储模式实现将视图存到另一个模式下

DECLARE
  -- 游标用于获取所有视图的名称
  CURSOR view_cursor IS
    SELECT VIEW_NAME
    FROM ALL_VIEWS
    WHERE OWNER = 'OLD_MODEL'; -- 获取 INDEX_SYSTEM 模式下的所有视图
  
  -- 用于存储视图名的变量
  view_name VARCHAR2(255);
  sql_create_table VARCHAR2(4096);
  sql_insert_data VARCHAR2(4096);
BEGIN
  -- 遍历所有视图
  FOR rec IN view_cursor LOOP
    view_name := rec.VIEW_NAME;
    
    -- 构造创建表的SQL语句
    sql_create_table := 'CREATE TABLE NEW_MODEL.' || view_name || ' AS SELECT * FROM OLD_MODEL.' || view_name;
    
    -- 执行创建表的SQL语句
    EXECUTE IMMEDIATE sql_create_table;
    
    -- 构造插入数据的SQL语句
    sql_insert_data := 'INSERT INTO NEW_MODEL.' || view_name || ' SELECT * FROM OLD_MODEL.' || view_name;
    
    -- 执行插入数据的SQL语句
    EXECUTE IMMEDIATE sql_insert_data;
    
    DBMS_OUTPUT.PUT_LINE('视图 ' || view_name || ' 已成功转存到 NEW_MODEL.');
  END LOOP;
END;
/

然后使用数据迁移工具将NEW_MODEL中的数据导出即可


http://www.kler.cn/a/508091.html

相关文章:

  • uniapp实现“到这儿去”、拨打电话功能
  • 核密度估计(Kernel Density Estimation, KDE)是一种非参数统计方法
  • 【Unity】unity3D 调用LoadSceneAsync 场景切换后比较暗 部门材质丢失
  • JAVA:在IDEA引入本地jar包的方法(不读取maven目录jar包)
  • C#与Vue2上传下载Excel文件
  • 基于R计算皮尔逊相关系数
  • Python 爬虫学习指南与资料分享
  • rsync结合inotify实现文件实时同步
  • Lua项目下SSRF利用Redis文件覆盖lua回显RCE
  • 人工智能之深度学习_[3] -PyTorch自动微分模块和构建线性回归模型
  • 1.1初探大模型:起源与发展
  • 如何将数据库字符集改为中文,让今后所有的数据库都支持中文
  • 二十三种设计模式-代理模式
  • IF=24.5! 综述:机器人纹理识别触觉感知和机器学习进展
  • 请求响应-
  • 【算法】差分
  • python爬取Boss直聘,分析北京招聘市场
  • Android-V lmkd 中的那些属性值
  • WORD转PDF脚本文件
  • 如何攻击一个服务器(仅用于教育及娱乐实验目的)
  • 从零用java实现 小红书 springboot vue uniapp (10)系统消息模块 接收推送消息优化
  • 浅谈计算机网络04 | 现代网络需求与技术支撑
  • C++内存分布
  • C++异常处理详解
  • P6周:VGG-16算法-Pytorch实现人脸识别
  • 深度学习 Pytorch 张量的索引、分片、合并以及维度调整