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

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp