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

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

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


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


前言

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

一、批量创建表

通过存储过程批量创建表
批量创建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;

相关文章
|
30天前
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
20 1
|
30天前
|
Java 关系型数据库 数据库连接
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
24 1
|
1月前
|
XML Java 数据库连接
WebGIS 信息系统-数据库设计
WebGIS 信息系统-数据库设计
40 0
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
101 1
|
2月前
|
存储 监控 安全
内网屏幕监控软件的数据存储与管理:使用SQLite数据库保存监控记录和配置信息
在当今数字化时代,安全和监控在企业和组织中变得至关重要。内网屏幕监控软件作为一种关键工具,帮助组织监视员工的活动并确保信息安全。这种软件不仅需要高效地记录和管理监控数据,还需要能够方便地进行配置和调整。本文将讨论如何使用SQLite数据库来保存监控记录和配置信息,并介绍如何通过自动化机制将监控到的数据提交到指定网站。
158 2
|
7天前
|
SQL 数据库 HIVE
Hive【基础知识 05】常用DDL操作(数据库操作+创建表+修改表+清空删除表+其他命令)
【4月更文挑战第8天】Hive【基础知识 05】常用DDL操作(数据库操作+创建表+修改表+清空删除表+其他命令)
19 0
|
15天前
|
存储 关系型数据库 MySQL
【mybatis-plus】Springboot+AOP+自定义注解实现多数据源操作(数据源信息存在数据库)
【mybatis-plus】Springboot+AOP+自定义注解实现多数据源操作(数据源信息存在数据库)
|
17天前
|
人工智能 分布式计算 Kubernetes
人工智能,应该如何测试?(三)数据构造与性能测试篇
本文探讨了人工智能场景中的性能测试,区别于传统互联网测试,其复杂性更高。主要关注点包括两类AI产品——业务类和平台类,后者涉及AI全生命周期,测试难度更大。测试重点是模型训练的性能,特别是数据模拟。需要构造大量结构化数据,如不同规模、分布、分片和特征规模的数据,以评估算法效率。此外,还涉及模拟设备规模(如视频流)和节点规模(边缘计算),以测试在大规模负载下的系统性能。文中提到了使用工具如Spark、ffmpeg、流媒体服务器和Kubernetes(K8S)的扩展项目,如Kubemark,来模拟大规模环境。最后,文章介绍了使用Golang进行异步IO操作以构建海量小文件,优化IO性能。
38 0
|
27天前
|
测试技术 数据库连接 数据库
测试环境的数据库连不了,打包报错怎么办
测试环境的数据库连不了,打包报错怎么办
15 0
|
27天前
|
SQL 关系型数据库 MySQL
Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中
Mysql数据库一个表字段中存了id,并以逗号分隔,id对应的详细信息在另一个表中
10 0

热门文章

最新文章