db2中create table as的建表方式

2024-04-25 22:32
文章标签 方式 建表 table db2 create

本文主要是介绍db2中create table as的建表方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DB2没有类似oracle的create table as select来定义表的方式,所以DB2中把SELECT查询出来的结果定义为别的表比较麻烦!


DB2定义表的3种方式:

首先创建一个例子表,再插入几条语句。

create table t1(col1 varchar(10));
create table t2 (col1 varchar(10),col2 varchar(20));
insert into t1 values ('1');
insert into t2 values ('1','ZXT');
describe select t1.col1,t2.col2 from t1,t2 where t1.col1=t2.col2;

一:按照常规的形式定义
首先describe sql,得到DDL,可以如下进行(describe select t1.col1,t2.col2 from t1,t2where t1.col1=t2.col2;)
然后根据DDL来创建table,最后把数据insert 过去。


二:汇总表方式
  需要3个步骤:
    1.创建汇总表

 create table tt as(select t1.col1,t2.col2 from t1,t2 where t1.col1=t2.col2)data initially deferredrefresh deferred;

 2.刷新数据

 refresh table tt;

 3.把汇总表改成一般的表

alter table tt drop materialized query;
 这个方法比较常用,好使没啥好说的,而且可以一次性就把数据刷新过去!

三:只定义表结构的形式
   需要2个步骤:
  
   1.创建表---只定义表结构

  create table tt as(select t1.col1,t2.col2 from t1,t2 where t1.col1=t2.col2) definition only;

   注:此步骤只定义了表结构,类似于oracle 的create XX as 语句
  
   2.插数据过来

insert into tt select t1.col1,t2.col2 from t1,t2 where t1.col1=t2.col2;
这是一个比较笨的方法,没什么好说的!今天总结了其他2中方法,现在分享给大家。


还有一种就是通过游标load进另外一个表中(采用游标,数据不需落地)

DECLARE mycursor CURSOR FOR SELECT col1, col2  FROM t2;
LOAD FROM mycursor OF CURSOR INSERT INTO t3;






这篇关于db2中create table as的建表方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/935965

相关文章

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

虚拟机与物理机的文件共享方式

《虚拟机与物理机的文件共享方式》文章介绍了如何在KaliLinux虚拟机中实现物理机文件夹的直接挂载,以便在虚拟机中方便地读取和使用物理机上的文件,通过设置和配置,可以实现临时挂载和永久挂载,并提供... 目录虚拟机与物理机的文件共享1 虚拟机设置2 验证Kali下分享文件夹功能是否启用3 创建挂载目录4

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red