mysql从一张表中取出数据插入到另一张表详细操作过程

本文主要是介绍mysql从一张表中取出数据插入到另一张表详细操作过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近有这样一个需求,原来的订单表wp_order设计不合理,原来的订单表没有订单详表,只有一张主表。现在是要重构订单表,原来的order表要废除,分为订单主表wp_order_master和订单详表wp_order_detail,需要把原来的wp_order中的数据拆分后插入这两张表。

我这里总结有3种mysql语句方式,分别是:
以下表1为目标表,表2为原表

  1. 表结构一样
insert into 表1select * from 表2

这个方式说白了就跟复制一样,要求2张表的所有字段一致,否则报错。

  1. 表结构不一样
insert into 表1 (列名1,列名2,列名3) select  列1,列2,列3 from 表2

这种也不能说是表结构不一样,其实就是有选择性的从表2取出数据对应表1字段插入。

  1. 只从另外一个表取部分字段
insert into 表1 (列名1,列名2,列名3) values(列1,列2,(select 列3 from 表2));

这种方式适用的情况是,在从表2取出部分字段数据的同时,表1有新的字段也需要数据,相当于第2种方式的升级版。

我这里采用第2种方式:

INSERT INTO wp_order_master (id,order_number,order_code,uid,cTime,pay_time,total_price,is_pay,
alipay_price,wechat_price,balance_price,cash_price,union_price,active_id,active_price,coupon_id,coupon_price,
integral_num,integral_price,erase_price,use_packet_id,order_from) SELECT id,order_number,order_code,uid,cTime,pay_time,total_price,is_pay,
alipay_price,wechat_price,balance_price,cash_price,union_price,active_id,active_price,coupon_id,coupon_price,
integral_num,integral_price,erase_price,use_packet_id,order_from FROM wp_order WHERE id BETWEEN 10 AND 20;

因为数据较多,在select的where后面加了条件,先少量测试确保数据能正确被拆分。

下面该把原order表内的商品信息拆分出来存入新的order_detail表内

原order表内把不同产品id各占一列,感觉不合理
在这里插入图片描述
现在的设计是order_detail表内是产品id在一列product_id,利用一个order_type(订单分类来区分)。构造出下面的拆分组装新数据的sql语句:

,在插入之前先单独把后面字段值部分的sql语句拿出来,测试看是否能得到想要插入的数据

SELECT id,order_type,
(
CASE 
WHEN course_id<>'0' THEN course_id
WHEN personal_course_id<>'0' THEN personal_course_id
WHEN camp_id<>'0' THEN camp_id
WHEN course_packet_id <>'0' THEN course_packet_id
WHEN vip_id<>'0' THEN vip_id
WHEN recharge_id<>'0' THEN recharge_id
ELSE
0
END
) as product_id,
goods_title,total_price unit_price,total_price subtotal,sales_id,coach_id,refund_time,refund_price 
FROM wp_order WHERE id BETWEEN 10 AND 20;

运行后完美得到了想要的数据
在这里插入图片描述
完整插入新表sql语句:

-- 把数据分拆到order_detail
INSERT INTO wp_order_detail (order_id,order_type,product_id,product_title,unit_price,subtotal,sales_id,coach_id,refund_time,refund_price)
SELECT id,order_type,
(
CASE 
WHEN course_id<>'0' THEN course_id
WHEN personal_course_id<>'0' THEN personal_course_id
WHEN camp_id<>'0' THEN camp_id
WHEN course_packet_id <>'0' THEN course_packet_id
WHEN vip_id<>'0' THEN vip_id
WHEN recharge_id<>'0' THEN recharge_id
ELSE
0
END
) as product_id,
goods_title,total_price unit_price,total_price subtotal,sales_id,coach_id,refund_time,refund_price 
FROM wp_order WHERE id BETWEEN 10 AND 20;

运行结果完美:
在这里插入图片描述
这下就可以把order_master和order_detail两张表清空

-- 清空order_master
TRUNCATE TABLE wp_order_master;

取消上面操作中select中where后的条件,一次性全部拆分重组插入数据,如果数据量太大,可以考虑加条件每次比如插入1000条。

这篇关于mysql从一张表中取出数据插入到另一张表详细操作过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Macos创建python虚拟环境的详细步骤教学

《Macos创建python虚拟环境的详细步骤教学》在macOS上创建Python虚拟环境主要通过Python内置的venv模块实现,也可使用第三方工具如virtualenv,下面小编来和大家简单聊聊... 目录一、使用 python 内置 venv 模块(推荐)二、使用 virtualenv(兼容旧版 P

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

MySQL 安装配置超完整教程

《MySQL安装配置超完整教程》MySQL是一款广泛使用的开源关系型数据库管理系统(RDBMS),由瑞典MySQLAB公司开发,目前属于Oracle公司旗下产品,:本文主要介绍MySQL安装配置... 目录一、mysql 简介二、下载 MySQL三、安装 MySQL四、配置环境变量五、配置 MySQL5.1

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可