MySQL表设计和聚合函数以及正则表达式示例详解

 更新时间:2025年07月24日 08:31:51   作者:缘来如此҉  
聚合函数在数据库管理和分析中有着广泛的应用场景,下面这篇文章主要给大家介绍了关于MySQL表设计和聚合函数以及正则表达式的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、第一范式(原子性)

要求:每列的值必须是不可再分的原子值。

例如:出生日期这一列存了某年某月某日,但是把出生日期这列可以拆分为年,月,日,三列,这样的列就不具有原子性。

二、第二范式(消除部分依赖)

要求:在满足第一范式的基础上,非主键列必须完全依赖整个主键(不能仅依赖主键的一部分)。

正例:
学生表:
学号,年龄,姓名。
学生选修成绩表:
学号,课程编号,成绩。
在学生表中,学号作为主键,通过学号,可以知道年龄,通过学号也可以知道姓名。这就是完全依赖。
在学生选修成绩表中,学号和课程编号作为复合主键,通过这个复合主键可以唯一确定学生的成绩。
反例:
学生选修课成绩表:
学号,姓名,年龄,课程名,学分,成绩。
这个表中学号作为主键,只有姓名和年龄完全依赖于学号主键,学分这个字段依赖于课程名,成绩字段依赖于课程名和学号这样的复合主键,所以这个表只能满足部分依赖。

三、第三范式(消除传递依赖)

要求:在满足第二范式的基础上,非主键列必须直接依赖主键,不能通过其他非主键列间接依赖(消除传递依赖)。

反例:
学生表:学号,姓名,年龄,所在院校,学院电话,学院地址。
这个表中学号作为主键,只有姓名和年龄和学号是强相关的。
院校电话和院校地址是和所在院校强相关的。
存在的传递关系:
学号->所在院校->学院电话->院校地址。
解决办法就是将学生表一分为二。
学生表:
学号,年龄,姓名,学院编号
学院表:
学院编号,学员名,学院电话,学院地址
用学院编号作为外键将两张表联系起来。
总结:

范式核心目标常见问题示例解决方案
1NF列原子性地址字段存复合信息拆分列
2NF消除部分主键依赖表的主键是组合键,非主键列依赖部分主键拆分表
3NF消除非主键间的传递依赖非主键列依赖其他非主键列拆分表,建立外键关联

四、表设计

一对一模型:

或者:

一对多:

在n端加入另一张表的主键。

多对多:

例如学生运动会的模型如下:

(1)有若干个班级,每个班级包括班级号、班级名、专业、人数。
(2)每个班级有若干个运动员,运动员只能属于一个班,包括运动员号、姓名、性别、年龄。
(3)有若干个比赛项目,包括项目号、名称、比赛地点。
(4)每个运动员可参加多个比赛项目,且每个项目可有多人参加。
(5)要求能够公布每个比赛项目的运动员名次与成绩。
(6)要求能够公布各个班级团体总分的名次和成绩。

E-R图:

关系模型:

运动员(运动员号,班级号,姓名,性别,年龄)
班级(班级号,班级名,专业,人数)
比赛项目(项目号,比赛地点,名称)
比赛(项目号,运动员号,成绩,名次)

五、聚合函数

函数名作用描述是否忽略 NULL示例代码(含 GROUP BY)
COUNT()统计行数或列值个数是(COUNT(*)除外)SELECT city, COUNT(*) FROM users GROUP BY city;
SUM()求数值列总和SELECT user_id, SUM(amount) FROM orders GROUP BY user_id;
AVG()求数值列平均值SELECT category, AVG(price) FROM products GROUP BY category;
MAX()返回列最大值SELECT user_id, MAX(order_date) FROM orders GROUP BY user_id;
MIN()返回列最小值`SELECT user_id, MIN(order_date) FROM
COUNT(DISTINCT)统计去重后的行数SELECT COUNT(DISTINCT city) FROM users;
HAVING对聚合结果二次过滤SELECT user_id, SUM(amount) AS total FROM orders GROUP BY user_id HAVING total>1000;

六、正则表达式

维度符号/语法作用说明(一句话)示例片段
字符集[a-z]任意单个小写字母[a-z]
[A-Z0-9]任意大写字母或数字[A-Z0-9]
[^abc]除 a、b、c 外的任意单个字符[^abc]
[[:alnum:]]任意字母或数字(POSIX 类)[[:alnum:]]
元字符.匹配除换行外的任意单个字符a.c → abc, a3c
^匹配字符串开头^abc
$匹配字符串结尾xyz$
\转义保留字符,使其按字面匹配\. 匹配真实点
|逻辑“或”cat|dog
量词*前一项 0 次或多次ab*c → ac, abc
+前一项 1 次或多次ab+c → abc, abbc
?前一项 0 次或 1 次ab?c → ac, abc
{n}前一项恰好 n 次a{3} → aaa
{n,m}前一项 n 到 m 次a{2,4} → aa, aaa
{n,}前一项至少 n 次a{2,} → aa, aaaa

示例1:查找 11 位手机号

SELECT * FROM users
WHERE phone REGEXP ‘^1[3-9][0-9]{9}$';

示例二: 查找邮箱格式

SELECT * FROM users
WHERE email REGEXP '^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{2,}$';

示例三:查找 18 位身份证号

SELECT * FROM users
WHERE id_card REGEXP '^[0-9]{17}[0-9Xx]$';

示例四:查找包含至少 1 个大写字母的密码字段

SELECT * FROM users
WHERE password REGEXP '[A-Z]';

完结。

总结

到此这篇关于MySQL表设计和聚合函数以及正则表达式示例详解的文章就介绍到这了,更多相关MySQL表设计和聚合函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解SQL注入--安全(二)

    详解SQL注入--安全(二)

    这篇文章主要介绍了SQL注入安全,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Mysql数据库增量备份的思路和方法

    Mysql数据库增量备份的思路和方法

    MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可,下面小编给大家分享Mysql数据库增量备份的思路详解,一起看看吧
    2017-09-09
  • windows 安装解压版 mysql5.7.28 winx64的详细教程

    windows 安装解压版 mysql5.7.28 winx64的详细教程

    这篇文章主要介绍了windows 安装解压版 mysql5.7.28 winx64的详细教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 浅谈开启magic_quote_gpc后的sql注入攻击与防范

    浅谈开启magic_quote_gpc后的sql注入攻击与防范

    通过启用php.ini配置文件中的相关选项,就可以将大部分想利用SQL注入漏洞的骇客拒绝于门外
    2012-01-01
  • MYSQL导入导出命令详解

    MYSQL导入导出命令详解

    网上看了一些总结出来的资料,不知道对大家有没有用的,有用的话也就不枉费我一按按钮的一片苦心了
    2007-09-09
  • MySQL存储路径迁移的详细步骤

    MySQL存储路径迁移的详细步骤

    在构建Web应用程序时,MySQL是存储数据的核心工具,在云服务器上,正确设置MySQL的存储路径对应用性能至关重要,通过迁移,我们不仅解决了空间不足的问题,还能让数据库运行得更快,所以本文将给大家介绍MySQL存储路径迁移的详细步骤,需要的朋友可以参考下
    2024-06-06
  • MySQL索引不会被用到的情况汇总

    MySQL索引不会被用到的情况汇总

    这篇文章主要给大家介绍了关于MySQL索引不会被用到的一些情况,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • linux下源码安装mysql5.6.20教程

    linux下源码安装mysql5.6.20教程

    这篇文章主要为大家详细介绍了linux下源码安装mysql5.6.20教程的相关资料,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL批量SQL插入性能优化详解

    MySQL批量SQL插入性能优化详解

    这篇文章主要为大家详细介绍了MySQL批量SQL插入性能优化,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • MySQL 8.0.0开发里程碑版发布!

    MySQL 8.0.0开发里程碑版发布!

    MySQL 8.0.0开发里程碑版发布,感兴趣的小伙伴们可以阅读一下
    2016-09-09

最新评论