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

相关文章

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

在macOS上安装jenv管理JDK版本的详细步骤

《在macOS上安装jenv管理JDK版本的详细步骤》jEnv是一个命令行工具,正如它的官网所宣称的那样,它是来让你忘记怎么配置JAVA_HOME环境变量的神队友,:本文主要介绍在macOS上安装... 目录前言安装 jenv添加 JDK 版本到 jenv切换 JDK 版本总结前言China编程在开发 Java

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

如何在Java Spring实现异步执行(详细篇)

《如何在JavaSpring实现异步执行(详细篇)》Spring框架通过@Async、Executor等实现异步执行,提升系统性能与响应速度,支持自定义线程池管理并发,本文给大家介绍如何在Sprin... 目录前言1. 使用 @Async 实现异步执行1.1 启用异步执行支持1.2 创建异步方法1.3 调用