mysql案例分析_MySQL查询语句

mysql案例分析_MySQL查询语句本文源码: ‘GitHub·点这里’ || ‘GitEE·点这里’ 一、连接查询 图解示意图 1、建表语句 部门和员工关系表: sql CREATE TABLE ( int(11) NOT NULL

本文源码:GitHub·点这里 || GitEE·点这里

一、连接查询

图解示意图

mysql案例分析_MySQL查询语句

1、建表语句

部门和员工关系表:

CREATE TABLE `tb_dept` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `deptName` varchar(30) DEFAULT NULL COMMENT '部门名称',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
CREATE TABLE `tb_emp` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `empName` varchar(20) DEFAULT NULL COMMENT '员工名称',
  `deptId` int(11) DEFAULT '0' COMMENT '部门ID',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

代码100分

2、七种连接查询

  • 图1:左外连接
代码100分select t1.*,t2.empName,t2.deptId 
from tb_dept t1 LEFT JOIN tb_emp t2 on t1.id=t2.deptId;
  • 图2:右外连接
select t1.*,t2.empName,t2.deptId 
from tb_dept t1 RIGHT JOIN tb_emp t2 on t1.id=t2.deptId;
  • 图3:内连接
代码100分select t1.*,t2.empName,t2.deptId 
from tb_dept t1 inner join tb_emp t2 on t1.id=t2.deptId;
  • 图4:左连接

查询tb_dept表特有的地方。

select t1.*,t2.empName,t2.deptId 
from tb_dept t1 LEFT JOIN tb_emp t2 on t1.id=t2.deptId
WHERE t2.deptId IS NULL;
  • 图5:右连接

查询tb_emp表特有的地方。

select t1.*,t2.empName,t2.deptId 
from tb_dept t1 RIGHT JOIN tb_emp t2 on t1.id=t2.deptId
WHERE t1.id IS NULL;
  • 图6:全连接
select t1.*,t2.empName,t2.deptId 
from tb_dept t1 LEFT JOIN tb_emp t2 on t1.id=t2.deptId
UNION
select t1.*,t2.empName,t2.deptId 
from tb_dept t1 RIGHT JOIN tb_emp t2 on t1.id=t2.deptId
  • 图7:全不连接

查询两张表互不关联到的数据。

select t1.*,t2.empName,t2.deptId 
from tb_dept t1 RIGHT JOIN tb_emp t2 on t1.id=t2.deptId
WHERE t1.id IS NULL
UNION
select t1.*,t2.empName,t2.deptId 
from tb_dept t1 LEFT JOIN tb_emp t2 on t1.id=t2.deptId
WHERE t2.deptId IS NULL

二、时间日期查询

1、建表语句

CREATE TABLE `ms_consume` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
  `user_id` int(11) NOT NULL COMMENT '用户ID',
  `user_name` varchar(20) NOT NULL COMMENT '用户名',
  `consume_money` decimal(20,2) DEFAULT '0.00' COMMENT '消费金额',
  `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8 COMMENT='消费表';

2、日期统计案例

  • 日期范围内首条数据

场景:产品日常运营活动中,经常见到这样规则:活动时间内,首笔消费满多少,优惠多少。

SELECT * FROM
    (
        SELECT * FROM ms_consume
        WHERE
            create_time 
        BETWEEN '2019-12-10 00:00:00' AND '2019-12-18 23:59:59'
        ORDER BY create_time
    ) t1
GROUP BY t1.user_id ;
  • 日期之间时差

场景:常用的倒计时场景

SELECT t1.*,
       timestampdiff(SECOND,NOW(),t1.create_time) second_diff 
FROM ms_consume t1 WHERE t1.id='9' ;
  • 查询今日数据
-- 方式一
SELECT * FROM ms_consume 
WHERE DATE_FORMAT(NOW(),'%Y-%m-%d')=DATE_FORMAT(create_time,'%Y-%m-%d');
-- 方式二
SELECT * FROM ms_consume 
WHERE TO_DAYS(now())=TO_DAYS(create_time) ;
  • 时间范围统计

场景:统计近七日内,消费次数大于两次的用户。

SELECT user_id,user_name,COUNT(user_id) userIdSum 
FROM ms_consume WHERE create_time>date_sub(NOW(), interval '7' DAY) 
GROUP BY user_id  HAVING userIdSum>1;
  • 日期范围内平均值

场景:指定日期范围内的平均消费,并排序。

SELECT * FROM
    (
        SELECT user_id,user_name,
            AVG(consume_money) avg_money
        FROM ms_consume t
        WHERE t.create_time BETWEEN '2019-12-10 00:00:00' 
                            AND '2019-12-18 23:59:59'
        GROUP BY user_id
    ) t1
ORDER BY t1.avg_money DESC;

三、树形表查询

1、建表语句

CREATE TABLE ms_city_sort (
    `id` INT (11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
    `city_name` VARCHAR (50) NOT NULL DEFAULT '' COMMENT '城市名称',
    `city_code` VARCHAR (50) NOT NULL DEFAULT '' COMMENT '城市编码',
    `parent_id` INT (11) NOT NULL DEFAULT '0' COMMENT '父级ID',
    `state` INT (11) NOT NULL DEFAULT '1' COMMENT '状态:1启用,2停用',
    `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
    `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',
    PRIMARY KEY (id)
) ENGINE = INNODB DEFAULT CHARSET = utf8 COMMENT = '城市分类管理';

2、直接SQL查询

SELECT t1.*, t2.parentName
FROM ms_city_sort t1
LEFT JOIN (
    SELECT
        m1.id,m2.city_name parentName
    FROM
        ms_city_sort m1,ms_city_sort m2
    WHERE m1.parent_id = m2.id
    AND m1.parent_id > 0
) t2 ON t1.id = t2.id;

3、函数查询

  • 查询父级名称
DROP FUNCTION IF EXISTS get_city_parent_name;
CREATE FUNCTION `get_city_parent_name`(pid INT) 
RETURNS varchar(50) CHARSET utf8
begin 
    declare parentName VARCHAR(50) DEFAULT NULL;
    SELECT city_name FROM ms_city_sort WHERE id=pid into parentName;
    return parentName;
end

SELECT t1.*,get_city_parent_name(t1.parent_id) parentName FROM ms_city_sort t1 ;
  • 查询根节点子级
DROP FUNCTION IF EXISTS get_root_child;
CREATE FUNCTION `get_root_child`(rootId INT) 
    RETURNS VARCHAR(1000) CHARSET utf8
    BEGIN 
        DECLARE resultIds VARCHAR(500); 
        DECLARE nodeId VARCHAR(500);
        SET resultIds = '%'; 
        SET nodeId = cast(rootId as CHAR);
        WHILE nodeId IS NOT NULL DO 
            SET resultIds = concat(resultIds,',',nodeId);
            SELECT group_concat(id) INTO nodeId 
            FROM ms_city_sort WHERE FIND_IN_SET(parent_id,nodeId)>0;
        END WHILE; 
        RETURN resultIds; 
END  ;

SELECT * FROM ms_city_sort WHERE FIND_IN_SET(id,get_root_child(5)) ORDER BY id ;

四、源代码地址

GitHub·地址
https://github.com/cicadasmile/mysql-data-base
GitEE·地址
https://gitee.com/cicadasmile/mysql-data-base

mysql案例分析_MySQL查询语句

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10386.html

(0)
上一篇 2022-12-28
下一篇 2022-12-28

相关推荐

  • Anaconda历史版本

    Anaconda历史版本作为数据科学家和Python开发者必备的一款工具,Anaconda拥有着众多的用户和高度的关注度。而随着科技的不断发展,Anaconda也在不断更新迭代,不同版本间的差异会对用户带来不同的使用体验。接下来本文将从多个方面详细介绍Anaconda的历史版本,带大家回顾、了解Anaconda的发展历程,以及各版本的新特性。

    2024-05-20
    46
  • impala使用教程_impala优化

    impala使用教程_impala优化###什么是Impala 用来处理存储在Hadoop集群中大量数据的大规模并行处理的sql查询引擎,它是由C++和Java编写的开源软件,它提供了访问Hadoop中分布式文件系统中的数据的最快的方法。

    2023-05-09
    122
  • Python词频统计代码

    Python词频统计代码在大量文本数据中,关键词的频次统计往往是必不可少的。无论是从市场营销角度还是从学术角度,词频统计都占有重要的地位。而Python作为一种擅长文本处理的编程语言,提供了一种快速而准确的词频统计方法。

    2024-06-29
    24
  • sqlserver 查找某个字段在哪些表里[亲测有效]

    sqlserver 查找某个字段在哪些表里[亲测有效]
    1 select * from [数据库名].[dbo].sysobjects where id in(select id from [数据库名].[dbo…

    2023-04-05
    127
  • plsql 调用方法[通俗易懂]

    plsql 调用方法[通俗易懂]CREATE OR REPLACE FUNCTION c_to_f (degree NUMBER) RETURN NUMBER IS buffer NUMBER; BEGIN buffer := (d

    2023-03-16
    129
  • 如何运行Python .py文件

    如何运行Python .py文件Python是一种通用编程语言,具有简单易学、高效快速的特点,因此被广泛应用于机器学习、数据分析、网络编程等领域。若想运行Python .py文件,本文将会给您提供一些有效的方法和实践经验。

    2024-05-07
    53
  • python之于java的异同(python 和 java 的区别)

    python之于java的异同(python 和 java 的区别)从语法上面的区分:Python版本的冒泡排序实现逻辑和Java版本冒泡排序实现逻辑几乎是相同,仅仅只有语法上有一定的区别。

    2023-11-18
    113
  • 使用Python正则表达式匹配字符串

    使用Python正则表达式匹配字符串正则表达式是一种强大的工具,可以在文本中搜索、匹配、替换特定的模式。Python的re模块提供了处理正则表达式的基本方法,使得我们能够高效地使用正则表达式进行字符串匹配。

    2024-05-08
    48

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注