天天看點

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各占一列,感覺不合理

mysql從一張表中取出資料插入到另一張表詳細操作過程

現在的設計是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;
           

運作後完美得到了想要的資料

mysql從一張表中取出資料插入到另一張表詳細操作過程

完整插入新表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;
           

運作結果完美:

mysql從一張表中取出資料插入到另一張表詳細操作過程

這下就可以把order_master和order_detail兩張表清空

-- 清空order_master
TRUNCATE TABLE wp_order_master;
           

取消上面操作中select中where後的條件,一次性全部拆分重組插入資料,如果資料量太大,可以考慮加條件每次比如插入1000條。