日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 多表關聯一對多查詢實現取最新一條數據的方法示例

瀏覽:31日期:2023-10-14 17:56:48

本文實例講述了MySQL 多表關聯一對多查詢實現取最新一條數據的方法。分享給大家供大家參考,具體如下:

MySQL 多表關聯一對多查詢取最新的一條數據遇到的問題多表關聯一對多查詢取最新的一條數據,數據出現重復

由于歷史原因,表結構設計不合理;產品告訴我說需要導出客戶信息數據,需要導出客戶的 所屬行業納稅性質 數據;但是這兩個字段卻在訂單表里面,每次客戶下單都會要求客戶填寫;由此可知,客戶數據和訂單數據是一對多的關系;那這樣的話,問題就來了,我到底以訂單中的哪一條數據為準呢?經過協商后一致同意以最新的一條數據為準;

數據測試初始化SQL腳本

DROP TABLE IF EXISTS `customer`;CREATE TABLE `customer` (`id` BIGINT NOT NULL COMMENT ’客戶ID’,`real_name` VARCHAR(20) NOT NULL COMMENT ’客戶名字’,`create_time` DATETIME NOT NULL COMMENT ’創建時間’,PRIMARY KEY(`id`))ENGINE=INNODB DEFAULT CHARSET = UTF8 COMMENT ’客戶信息表’;-- DATA FOR TABLE customerINSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7717194510959685632’, ’張三’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7718605481599623168’, ’李四’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7720804666226278400’, ’王五’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7720882041353961472’, ’劉六’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722233303626055680’, ’寶寶’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722233895811448832’, ’小寶’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722234507982700544’, ’大寶’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722234927631204352’, ’二寶’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722235550724423680’, ’小賤’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722235921488314368’, ’小明’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722238233975881728’, ’小黑’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722246644138409984’, ’小紅’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722318634321346560’, ’阿狗’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722318674321346586’, ’阿嬌’, ’2019-01-23 16:23:05’);INSERT INTO `demo`.`customer` (`id`, `real_name`, `create_time`) VALUES (’7722318974421546780’, ’阿貓’, ’2019-01-23 16:23:05’);DROP TABLE IF EXISTS `order_info`;CREATE TABLE `order_info` (`id` BIGINT NOT NULL COMMENT ’訂單ID’,`industry` VARCHAR(255) DEFAULT NULL COMMENT ’所屬行業’, `nature_tax` VARCHAR(255) DEFAULT NULL COMMENT ’納稅性質’,`customer_id` VARCHAR(20) NOT NULL COMMENT ’客戶ID’,`create_time` DATETIME NOT NULL COMMENT ’創建時間’,PRIMARY KEY(`id`))ENGINE=INNODB DEFAULT CHARSET = UTF8 COMMENT ’訂單信息表’;-- DATA FOR TABLE order_infoINSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700163609453207552’, ’餐飲酒店類’, ’小規模’, ’7717194510959685632’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700163609453207553’, ’餐飲酒店類’, ’小規模’, ’7717194510959685632’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700167995646615552’, ’高新技術’, ’一般納稅人’, ’7718605481599623168’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700167995646615553’, ’商貿’, ’一般納稅人’, ’7718605481599623168’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700193633216569344’, ’商貿’, ’一般納稅人’, ’7720804666226278400’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700193633216569345’, ’高新技術’, ’一般納稅人’, ’7720804666226278400’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700197875671179264’, ’餐飲酒店類’, ’一般納稅人’, ’7720882041353961472’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7700197875671179266’, ’餐飲酒店類’, ’一般納稅人’, ’7720882041353961472’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7703053372673171456’, ’高新技術’, ’小規模’, ’7722233303626055680’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7703053372673171457’, ’高新技術’, ’小規模’, ’7722233303626055680’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709742385262698496’, ’服務類’, ’一般納稅人’, ’7722233895811448832’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709742385262698498’, ’服務類’, ’一般納稅人’, ’7722233895811448832’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745055683780608’, ’高新技術’, ’小規模’, ’7722234507982700544’, ’2019-01-23 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745055683780609’, ’進出口’, ’小規模’, ’7722234507982700544’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745249439653888’, ’文化體育’, ’一般納稅人’, ’7722234927631204352’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745249439653889’, ’高新技術’, ’一般納稅人’, ’7722234927631204352’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745453266051072’, ’高新技術’, ’小規模’, ’7722235550724423680’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745453266051073’, ’文化體育’, ’小規模’, ’7722235550724423680’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745539848413184’, ’科技’, ’一般納稅人’, ’7722235921488314368’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745539848413185’, ’高新技術’, ’一般納稅人’, ’7722235921488314368’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745652603887616’, ’高新技術’, ’一般納稅人’, ’7722238233975881728’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745652603887617’, ’科技’, ’一般納稅人’, ’7722238233975881728’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745755528568832’, ’進出口’, ’一般納稅人’, ’7722246644138409984’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745755528568833’, ’教育咨詢’, ’小規模’, ’7722246644138409984’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745892539047936’, ’教育咨詢’, ’一般納稅人’, ’7722318634321346560’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709745892539047937’, ’進出口’, ’一般納稅人’, ’7722318634321346560’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709746000127139840’, ’生產類’, ’小規模’, ’7722318674321346586’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709746000127139841’, ’農業’, ’一般納稅人’, ’7722318674321346586’, ’2019-01-23 17:09:53’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709746447445467136’, ’農業’, ’一般納稅人’, ’7722318974421546780’, ’2019-01-24 16:54:25’);INSERT INTO `demo`.`order_info` (`id`, `industry`, `nature_tax`, `customer_id`, `create_time`) VALUES (’7709746447445467137’, ’生產類’, ’小規模’, ’7722318974421546780’, ’2019-01-23 17:09:53’); 按需求寫的SQL語句:

UPDATE order_info SET create_time = NOW(); 嘗試解決問題

SELECTcr.id,cr.real_name,oi.industry,oi.nature_taxFROMcustomer AS crLEFT JOIN (SELECT a.industry, a.nature_tax, a.customer_id, a.create_time FROM order_info AS aLEFT JOIN (SELECT MAX(create_time) AS create_time, customer_id FROM order_info GROUP BY customer_id) AS b ON a.customer_id = b.customer_idWHERE a.create_time = b.create_time) AS oi ON oi.customer_id = cr.idGROUP BY cr.id;

數據重復嘛,小意思,加個 GROUP BY 不就解決了嗎?我怎么會這么機智,哈哈哈!!!但是當我執行完SQL的那一瞬間,我又懵逼了,查詢出來的結果中 所屬行業納稅性質 仍然不是最新的;看來是我想太多了,還是老老實實的解決問題吧。。。

找出重復數據

SELECTcr.id,cr.real_name,oi.industry,oi.nature_taxFROMcustomer AS crLEFT JOIN (SELECT a.industry, a.nature_tax, a.customer_id, a.create_time FROM order_info AS aLEFT JOIN (SELECT MAX(create_time) AS create_time, customer_id FROM order_info GROUP BY customer_id) AS b ON a.customer_id = b.customer_idWHERE a.create_time = b.create_time) AS oi ON oi.customer_id = cr.idGROUP BY cr.id HAVING COUNT(cr.id) >= 2; 執行結果如下:

SELECTcr.id,cr.real_name,oi.industry,oi.nature_taxFROMcustomer AS crLEFT JOIN (SELECT a.industry, a.nature_tax, a.customer_id, a.create_time FROM order_info AS aLEFT JOIN (SELECT MAX(id) AS id, customer_id FROM order_info GROUP BY customer_id) AS b ON a.customer_id = b.customer_idWHERE a.id = b.id) AS oi ON oi.customer_id = cr.id;

哎,終于解決了。。。

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产99精品一区| 在线视频观看日韩| 黄色成人91| 久久视频国产| 99视频精品全国免费| 国产一区二区三区四区大秀| 久久亚洲道色| 精品美女在线视频| 国产91在线播放精品| 国产高清不卡| 欧美精选视频一区二区| 私拍精品福利视频在线一区| 久久视频国产| 视频在线观看一区| 蜜桃视频在线观看一区二区| 亚洲久久在线| 天堂av一区| 国产精品自在| 精品女同一区二区三区在线观看| 色婷婷综合网| 色婷婷久久久| 亚洲欧美日本视频在线观看| 婷婷视频一区二区三区| 青青草国产精品亚洲专区无| 欧美1区2区3| 中文字幕高清在线播放| 久久久久国产一区二区| 黄色成人在线网址| 日韩精品电影一区亚洲| 国产精品久久久久久妇女| 免费在线播放第一区高清av| 国产在线一区不卡| 久久蜜桃精品| 日韩中文字幕一区二区三区| 久久国产日韩欧美精品| 久久久国产精品网站| 神马午夜在线视频| 亚洲精华国产欧美| 青青草伊人久久| 高清一区二区三区av| 九九久久婷婷| 亚洲欧美网站在线观看| 欧美激情福利| 国产视频一区欧美| 国产欧美久久一区二区三区| 神马久久午夜| 视频一区二区国产| 日韩高清不卡一区二区| 99国产精品久久久久久久成人热| 精精国产xxxx视频在线播放| 日韩精品一区二区三区免费视频| 久久天堂成人| 美日韩精品视频| 亚洲免费婷婷| 欧美亚洲二区| 久久香蕉网站| 日韩av在线中文字幕| 蜜臀久久99精品久久一区二区| 日韩中文字幕麻豆| 精品99在线| 久久国产成人| 国产欧美日韩综合一区在线播放| 日韩av免费| 欧美日韩一区二区三区不卡视频| 日韩电影二区| 日韩 欧美一区二区三区| 日韩av自拍| 亚洲欧美一级| 视频福利一区| 欧美精品国产一区| 国产一区亚洲| 免费看一区二区三区| 日韩午夜电影| 国内精品美女在线观看| 蜜臀国产一区二区三区在线播放| 国产探花在线精品一区二区| 99久久亚洲精品蜜臀| 精品一级视频| 亚洲精华国产欧美| 久久久久伊人| 在线亚洲成人| 精品视频99| 综合激情五月婷婷| 久久精品1区| 国产精品欧美大片| 免费日韩av| 日韩成人亚洲| 国产精品115| 深夜福利亚洲| 精品一区毛片| 欧美亚洲日本精品| 日韩avvvv在线播放| 久久久亚洲一区| 国产福利资源一区| 亚洲免费毛片| 国产亚洲一级| 亚洲播播91| 精品美女在线视频| 欧美私人啪啪vps| 视频在线观看国产精品| 久久亚洲精品中文字幕蜜潮电影| 国产精品嫩模av在线| 亚洲一区二区免费看| 亚洲风情在线资源| 国产中文欧美日韩在线 | 久久国产精品免费精品3p| 色8久久久久| 国产欧美另类| 亚洲精品电影| av在线资源| 国产伦一区二区三区| 亚洲欧洲日本mm| 99久久亚洲精品蜜臀| 精品视频亚洲| 日本欧美在线看| 久久狠狠亚洲综合| 日本亚州欧洲精品不卡| 亚洲免费激情| 国产精品丝袜xxxxxxx| 欧美在线网站| 色黄视频在线观看| 日本精品在线中文字幕| 天堂√8在线中文| 亚洲午夜久久久久久尤物| 你懂的国产精品永久在线| 麻豆精品视频在线观看免费| 亚洲欧美日韩视频二区| 欧美xxxx中国| 欧美日韩精品免费观看视欧美高清免费大片 | 久久久夜夜夜| 欧美三区不卡| 你懂的国产精品| 秋霞影院一区二区三区| 久久人人精品| 99视频精品视频高清免费| 欧美xxxx中国| 日韩av一区二区在线影视| 在线视频观看日韩| 亚洲欧洲日韩| 免费在线播放第一区高清av| 免费日韩av片| 日韩午夜黄色| 国产精品99久久免费观看| 亚洲我射av| 亚洲区国产区| 久久精品99国产精品日本| 国产亚洲亚洲| 欧美日韩国产欧| 国产成人1区| 久久精品国产99国产| 国产精品久一| 你懂的亚洲视频| 少妇久久久久| 久久亚洲不卡| 三级一区在线视频先锋| 日韩成人午夜精品| 青青草国产精品亚洲专区无| 久久永久免费| 婷婷激情一区| 天堂网av成人| 模特精品在线| 欧美亚洲三级| 久久av日韩| 国产一区二区三区探花| av高清一区| 亚洲欧洲免费| 久久中文在线| 少妇久久久久| 亚洲精品在线a| 日韩欧美激情电影| 精品国产美女a久久9999| 精品视频自拍| 午夜久久影院| 国产精品乱战久久久| 日韩综合精品| 免费日韩一区二区| 成人美女视频| 亚洲深夜福利在线观看| 日本免费在线视频不卡一不卡二| 九一精品国产| 亚洲91视频| 欧美成人基地 | 亚洲一区二区免费看| 久久99蜜桃| 久久字幕精品一区| 欧美激情三区| 美女av在线免费看| 日韩精品欧美| 国产高清一区| 久久久蜜桃一区二区人| 免费视频一区二区三区在线观看| 国产精品视频一区二区三区| 日本亚州欧洲精品不卡| 日韩精品一区二区三区中文 | 亚洲成人三区| 日韩天堂av| 日日夜夜免费精品视频| 国产欧美日韩综合一区在线播放| 亚洲激情久久| 蜜桃视频第一区免费观看|