电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:3日期: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 數據庫
相關文章:
主站蜘蛛池模板: 北京西风东韵品牌与包装设计公司,创造视觉销售力! | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | MTK核心板|MTK开发板|MTK模块|4G核心板|4G模块|5G核心板|5G模块|安卓核心板|安卓模块|高通核心板-深圳市新移科技有限公司 | 深圳离婚律师咨询「在线免费」华荣深圳婚姻律师事务所专办离婚纠纷案件 | ★济南领跃标识制作公司★济南标识制作,标牌制作,山东标识制作,济南标牌厂 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 电镀标牌_电铸标牌_金属标贴_不锈钢标牌厂家_深圳市宝利丰精密科技有限公司 | 广州展览设计公司_展台设计搭建_展位设计装修公司-众派展览装饰 广州展览制作工厂—[优简]直营展台制作工厂_展会搭建资质齐全 | 电缆桥架生产厂家_槽式/梯式_热镀锌线槽_广东东莞雷正电气 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 鄂泉泵业官网|(杭州、上海、全国畅销)大流量防汛排涝泵-LW立式排污泵 | 气动隔膜泵-电动隔膜泵-循环热水泵-液下排污/螺杆/管道/化工泵「厂家」浙江绿邦 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 电动打包机_气动打包机_钢带捆扎机_废纸打包机_手动捆扎机 | MTK核心板|MTK开发板|MTK模块|4G核心板|4G模块|5G核心板|5G模块|安卓核心板|安卓模块|高通核心板-深圳市新移科技有限公司 | 数年网路-免费在线工具您的在线工具箱-shuyear.com | 深圳南财多媒体有限公司介绍| 天津热油泵_管道泵_天津高温热油泵-天津市金丰泰机械泵业有限公司【官方网站】 | 干粉砂浆设备-干粉砂浆生产线-干混-石膏-保温砂浆设备生产线-腻子粉设备厂家-国恒机械 | 磁棒电感生产厂家-电感器厂家-电感定制-贴片功率电感供应商-棒形电感生产厂家-苏州谷景电子有限公司 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | STRO|DTRO-STRO反渗透膜(科普)_碟滤 | 采暖炉_取暖炉_生物质颗粒锅炉_颗粒壁炉_厂家加盟批发_烟台蓝澳采暖设备有限公司 | 运动木地板厂家_体育木地板安装_篮球木地板选购_实木运动地板价格 | 电竞学校_电子竞技培训学校学院-梦竞未来电竞学校官网 | 脑钠肽-白介素4|白介素8试剂盒-研域(上海)化学试剂有限公司 | 四川成都干燥设备_回转筒干燥机_脉冲除尘器_输送设备_热风炉_成都川工星科机电设备有限公司 | 室内室外厚型|超薄型|非膨胀型钢结构防火涂料_隧道专用防火涂料厂家|电话|价格|批发|施工 | 博客-悦享汽车品质生活| STRO|DTRO-STRO反渗透膜(科普)_碟滤 | 网站seo优化_seo云优化_搜索引擎seo_启新网络服务中心 | 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 | 科普仪器菏泽市教育教学仪器总厂 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 钢衬四氟管道_钢衬四氟直管_聚四氟乙烯衬里管件_聚四氟乙烯衬里管道-沧州汇霖管道科技有限公司 | 便携式高压氧舱-微压氧舱-核生化洗消系统-公众洗消站-洗消帐篷-北京利盟救援 | 深圳工程师职称评定条件及流程_深圳职称评审_职称评审-职称网 | 济南玻璃安装_济南玻璃门_济南感应门_济南玻璃隔断_济南玻璃门维修_济南镜片安装_济南肯德基门_济南高隔间-济南凯轩鹏宇玻璃有限公司 | 自动部分收集器,进口无油隔膜真空泵,SPME固相微萃取头-上海楚定分析仪器有限公司 | 三效蒸发器_多效蒸发器价格_四效三效蒸发器厂家-青岛康景辉 |