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

DM8数据库批量创建表,插入数据,更改表信息,删除测试表

DM8数据库批量创建表,插入数据,更改表信息,删除测试表


在测试产品的功能和性能的时候需要大量数据表,我们可以通过游标存储过程批量创建测试表,插入测试数据,更改测试表,删除测试表。

文章目录

  • DM8数据库批量创建表,插入数据,更改表信息,删除测试表
  • 前言
  • 一、批量创建表
    • 方法一
    • 方法二
  • 二、批量插入数据
    • 在指定的表中批量插入数据
    • 方法1:批量创建表并且批量插入数据
    • 方法2:批量创建表并且批量插入数据
  • 三、批量更改表信息
    • 批量给表添加列信息
  • 四、批量删除测试表
    • 删除创建的测试表


前言

在测试产品的功能和性能的时候需要大量数据表,我们可以通过游标存储过程批量创建测试表,插入测试数据,更改测试表,删除测试表。

一、批量创建表

通过存储过程批量创建表
批量创建100张表

方法一

--批量创建100张表
DECLARE
i int:=1;
BEGIN
for num in i..100 loop--创建100张表
execute immediate'CREATE TABLE tab_'||i||'( num int primary key ,name varchar(30))';
i:=i+1;
end loop;
end;

方法二

--批量创建100张表
DECLARE
  t_sql varchar2(3000);
  t_i number(22);
  t_count number(22);
BEGIN
t_count:=100;--输入你想创建表的个数
for i in 1..t_count
loop
t_sql:='CREATE TABLE tab_'||i||'( num int primary key ,name varchar(30))';
execute immediate t_sql;
end loop;
end;

方法二是一个模板,几乎万能的,只需要再更改一下sql语句。


二、批量插入数据

通过存储过程插入数据

在指定的表中批量插入数据

BEGIN
for T in 1..100
loop
insert into
SYSDBA.tab_1 values(
T,
repeatstr('pby',3)--批量插入100条,重复3遍的pby
);
if T MOD 100 =0 then
commit;
end if;
end loop;
commit;
end;

方法1:批量创建表并且批量插入数据

declare 
  v_sql varchar(3000);
  v_sql_2 varchar(3000);
  v_i number(22);
  v_count number(22);
begin
  v_count:=100;--批量创建100张表
  for i in 1..v_count
   loop
   
  v_sql:='CREATE TABLE tab_'||i||'( num int ,name varchar(30))';
   v_sql_2:='insert into tab_'||i||' values(1,2)';--批量插入数据
   
    execute immediate v_sql;
    execute immediate v_sql_2;
  end loop;
end;

方法2:批量创建表并且批量插入数据

DECLARE
i int:=1;
BEGIN
for a in 1..100 loop--批量创建100张表
execute immediate'CREATE TABLE tab_'||i||'( num int ,name varchar(30))';
execute immediate'insert into tab_'||i||' values(1,2)';
i:=i+1;
end loop;
commit;
end;

三、批量更改表信息

通过游标更改表信息

批量给表添加列信息

declare 
v_sql varchar2(3000);
CURSOR CUR_TAB IS
  SELECT TABLE_NAME from USER_TABLES where TABLE_NAME like 'tab_%';--所有前缀为tab_的表
BEGIN
for GET_TAB in CUR_TAB
  loop
v_sql:='alter table ' || GET_TAB.TABLE_NAME ||
' add age varchar(30)';
     execute immediate v_sql;
   end loop;
end;

四、批量删除测试表

通过游标删除测试表

删除创建的测试表

declare --功能删除所有测试表
v_sql varchar2(3000);
CURSOR CUR_TAB IS
  SELECT TABLE_NAME from USER_TABLES where TABLE_NAME like 'TAB_%';
BEGIN
for GET_TAB in CUR_TAB
  loop
v_sql:='drop table ' || GET_TAB.TABLE_NAME ;
     execute immediate v_sql;
   end loop;
end;

相关文章:

  • mysql插入记录时违反唯一索引的处理
  • 创建型模式-工厂方法模式(二)
  • 面试的时候要注意的坑
  • 虹科案例 | 虹科HiveMQ助力实现百万辆汽车智能互联
  • Nginx基础篇-Nginx的WEB模块~连接状态
  • 营收、利润双增长,龙湖集团找到多元增长的答案?
  • YOLO系列之yolov1解读(1)
  • Softing IT Networks线上研讨会 | 9月 (下篇)
  • HBase原理深入
  • webpack5 之 基础构建打包
  • STM32使用寄存器点灯实验
  • 技术对接35
  • 金仓数据库 KingbaseES 插件参考手册 plsql_pldbgapi
  • 测试面试 | 某 BAT 大厂测试开发面试真题与重点解析
  • 2022鹏城杯
  • 【391天】每日项目总结系列128(2018.03.03)
  • Create React App 使用
  • Github访问慢解决办法
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • LeetCode18.四数之和 JavaScript
  • Node + FFmpeg 实现Canvas动画导出视频
  • orm2 中文文档 3.1 模型属性
  • PHP 使用 Swoole - TaskWorker 实现异步操作 Mysql
  • React系列之 Redux 架构模式
  • session共享问题解决方案
  • Vue.js-Day01
  • Webpack4 学习笔记 - 01:webpack的安装和简单配置
  • 首页查询功能的一次实现过程
  • 通信类
  • 交换综合实验一
  • 新海诚画集[秒速5センチメートル:樱花抄·春]
  • ​HTTP与HTTPS:网络通信的安全卫士
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • ###C语言程序设计-----C语言学习(6)#
  • #Linux杂记--将Python3的源码编译为.so文件方法与Linux环境下的交叉编译方法
  • #pragma预处理命令
  • #微信小程序:微信小程序常见的配置传旨
  • (13)Hive调优——动态分区导致的小文件问题
  • (3)选择元素——(17)练习(Exercises)
  • (4)logging(日志模块)
  • (C语言)fgets与fputs函数详解
  • (二)fiber的基本认识
  • (附源码)spring boot基于小程序酒店疫情系统 毕业设计 091931
  • (附源码)springboot电竞专题网站 毕业设计 641314
  • (免费领源码)Java#Springboot#mysql农产品销售管理系统47627-计算机毕业设计项目选题推荐
  • (十一)图像的罗伯特梯度锐化
  • (四) 虚拟摄像头vivi体验
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (转)程序员技术练级攻略
  • (轉貼) 蒼井そら挑戰筋肉擂台 (Misc)
  • (状压dp)uva 10817 Headmaster's Headache
  • *_zh_CN.properties 国际化资源文件 struts 防乱码等
  • 、写入Shellcode到注册表上线
  • .NET DataGridView数据绑定说明
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter