百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

Mysql5.7学习笔记2023-7-6数据库入门3

qiyuwang 2025-03-11 20:54 5 浏览 0 评论

MySQL是一种开源的关系型数据库管理系统,广泛应用于Web应用程序的后台数据存储。在学习MySQL数据库的过程中,掌握函数的使用方法和特点是非常重要的。下面将通过3个样例来介绍一些常用的函数,并对这些函数对数据库的计算压力进行讨论。

  1. CONCAT函数
    CONCAT函数用于将多个字符串连接在一起。例如,我们有一个名为"students"的表,其中包含"first_name"和"last_name"两个列。我们可以使用CONCAT函数将这两个列的值连接在一起,并将结果作为新的列插入到表中。
INSERT INTO students (full_name)
SELECT CONCAT(first_name, ' ', last_name) AS full_name
FROM students;
  1. SELECT函数
    SELECT函数用于从数据库中选择数据。它可以根据条件过滤数据,并可以使用聚合函数对数据进行计算。例如,我们可以使用SELECT函数从"students"表中选择所有姓氏为"Smith"的学生,并计算他们的平均年龄。
SELECT AVG(age) AS average_age
FROM students
WHERE last_name = 'Smith';
  1. UPDATE函数
    UPDATE函数用于更新数据库中的数据。例如,我们可以使用UPDATE函数将"students"表中所有姓氏为"Smith"的学生的年龄增加1岁。
UPDATE students
SET age = age + 1
WHERE last_name = 'Smith';

除了上面介绍的函数,还有许多其他常用的函数,如COUNT、SUM、AVG、SUBSTRING、LENGTH、REPLACE、UPPER、LOWER、TRIM、ABS、ROUND、CEIL、FLOOR、RAND、NOW、CURDATE、DATE_FORMAT、DATE_ADD、DATE_SUB、DATEDIFF、IF、CASE、MIN、MAX、GROUP_CONCAT、GROUP BY等。这些函数具有不同的功能和特点,可以根据实际需求选择使用。

对于以上函数对数据库的计算压力,其影响因素主要包括数据量、查询复杂度和索引的使用。函数的计算需要占用一定的CPU和内存资源,而数据量过大或查询复杂度较高会增加计算的时间和资源消耗。此外,索引的使用可以提高查询效率,减少计算压力。

综上所述,学习和掌握MySQL数据库中的函数的使用方法和特点对于进行高效的数据处理和查询非常重要。在使用这些函数时,需要根据实际需求选择合适的函数,并合理优化查询语句以减少计算压力。

MySQL是一种关系型数据库管理系统,其中的函数可以帮助我们进行数据的计算和处理。本文将介绍MySQL 5中一些常用的函数,包括CONCAT、INSERT、SELECT、UPDATE、DELETE、COUNT、SUM、AVG、SUBSTRING、LENGTH、REPLACE、UPPER、LOWER、TRIM、ABS、ROUND、CEIL、FLOOR、RAND、NOW、CURDATE、DATE_FORMAT、DATE_ADD、DATE_SUB、DATEDIFF、IF、CASE、MIN、MAX、GROUP_CONCAT、GROUP BY,并探讨它们对数据库的计算压力。

1. CONCAT函数

CONCAT函数用于将两个或多个字符串连接在一起。它的语法如下:

CONCAT(string1, string2, ...)

例如,假设我们有一个名为customers的表,其中有first_name和last_name两列,我们可以使用CONCAT函数将它们连接在一起:

SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM customers;

这将返回一个新的列full_name,其中包含了first_name和last_name的连接结果。

2. INSERT语句

INSERT语句用于向表中插入新的行。它的语法如下:

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...)

例如,假设我们有一个名为students的表,其中有id、name和age三列,我们可以使用INSERT语句向表中插入新的行:

INSERT INTO students (id, name, age)
VALUES (1, 'John', 20);

这将在students表中插入一行数据。

3. SELECT语句

SELECT语句用于从表中查询数据。它的语法如下:

SELECT column1, column2, ...
FROM table_name
WHERE condition;

例如,假设我们有一个名为products的表,其中有id、name和price三列,我们可以使用SELECT语句查询表中的数据:

SELECT name, price FROM products WHERE price > 100;

这将返回products表中price大于100的所有行的name和price列。

4. UPDATE语句

UPDATE语句用于更新表中的数据。它的语法如下:

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

例如,假设我们有一个名为orders的表,其中有id、status和amount三列,我们可以使用UPDATE语句更新表中的数据:

UPDATE orders SET status = 'completed' WHERE id = 1;

这将更新orders表中id为1的行的status列。

5. DELETE语句

DELETE语句用于从表中删除行。它的语法如下:

DELETE FROM table_name WHERE condition;

例如,假设我们有一个名为customers的表,我们可以使用DELETE语句删除表中满足条件的行:

DELETE FROM customers WHERE age > 60;

这将删除customers表中age大于60的所有行。

6. COUNT函数

COUNT函数用于计算表中满足条件的行数。它的语法如下:

COUNT(expression)

例如,假设我们有一个名为students的表,其中有id、name和age三列,我们可以使用COUNT函数计算表中年龄大于等于18岁的学生人数:

SELECT COUNT(*) AS num_students FROM students WHERE age >= 18;

这将返回一个新的列num_students,其中包含了年龄大于等于18岁的学生人数。

7. SUM函数

SUM函数用于计算表中某列的总和。它的语法如下:

SUM(expression)

例如,假设我们有一个名为orders的表,其中有id、amount和status三列,我们可以使用SUM函数计算表中已完成订单的总金额:

SELECT SUM(amount) AS total_amount FROM orders WHERE status = 'completed';

这将返回一个新的列total_amount,其中包含了已完成订单的总金额。

8. AVG函数

AVG函数用于计算表中某列的平均值。它的语法如下:

AVG(expression)

例如,假设我们有一个名为students的表,其中有id、name和score三列,我们可以使用AVG函数计算表中学生的平均分数:

SELECT AVG(score) AS average_score FROM students;

这将返回一个新的列average_score,其中包含了学生的平均分数。

9. SUBSTRING函数

SUBSTRING函数用于提取字符串的子串。它的语法如下:

SUBSTRING(string, start, length)

例如,假设我们有一个名为employees的表,其中有id和name两列,我们可以使用SUBSTRING函数提取name列的前三个字符:

SELECT SUBSTRING(name, 1, 3) AS initials FROM employees;

这将返回一个新的列initials,其中包含了name列的前三个字符。

10. LENGTH函数

LENGTH函数用于计算字符串的长度。它的语法如下:

LENGTH(string)

例如,假设我们有一个名为products的表,其中有id和name两列,我们可以使用LENGTH函数计算name列的长度:

SELECT LENGTH(name) AS name_length FROM products;

这将返回一个新的列name_length,其中包含了name列的长度。

11. REPLACE函数

REPLACE函数用于替换字符串中的子串。它的语法如下:

REPLACE(string, from_string, to_string)

例如,假设我们有一个名为texts的表,其中有id和content两列,我们可以使用REPLACE函数将content列中的所有"apple"替换为"orange":

UPDATE texts SET content = REPLACE(content, 'apple', 'orange');

这将更新texts表中content列中的数据。

12. UPPER函数和LOWER函数

UPPER函数和LOWER函数分别用于将字符串转换为大写和小写。它们的语法如下:

UPPER(string)
LOWER(string)

例如,假设我们有一个名为customers的表,其中有id和name两列,我们可以使用UPPER函数将name列中的字符串转换为大写:

SELECT UPPER(name) AS uppercase_name FROM customers;

这将返回一个新的列uppercase_name,其中包含了name列中的字符串转换为大写后的结果。

13. TRIM函数

TRIM函数用于去除字符串两端的空格。它的语法如下:

TRIM(string)

例如,假设我们有一个名为employees的表,其中有id和name两列,我们可以使用TRIM函数去除name列中的空格:

SELECT TRIM(name) AS trimmed_name FROM employees;

这将返回一个新的列trimmed_name,其中包含了去除了name列两端空格的结果。

14. ABS函数

ABS函数用于计算数值的绝对值。它的语法如下:

ABS(number)

例如,假设我们有一个名为transactions的表,其中有id和amount两列,我们可以使用ABS函数计算amount列中的数值的绝对值:

SELECT ABS(amount) AS absolute_amount FROM transactions;

这将返回一个新的列absolute_amount,其中包含了amount列中数值的绝对值。

15. ROUND函数、CEIL函数和FLOOR函数

ROUND函数用于对数值进行四舍五入,CEIL函数用于向上取整,FLOOR函数用于向下取整。它们的语法如下:

ROUND(number, decimals)
CEIL(number)
FLOOR(number)

例如,假设我们有一个名为prices的表,其中有id和price两列,我们可以使用ROUND函数将price列中的数值四舍五入到两位小数:

SELECT ROUND(price, 2) AS rounded_price FROM prices;

这将返回一个新的列rounded_price,其中包含了price列中数值四舍五入到两位小数的结果。

16. RAND函数

RAND函数用于生成一个随机数。它的语法如下:

RAND()

例如,假设我们有一个名为numbers的表,其中有id和value两列,我们可以使用RAND函数生成一个随机数并插入到value列中:

UPDATE numbers SET value = RAND();

这将更新numbers表中value列的数据。

17. NOW函数、CURDATE函数和DATE_FORMAT函数

NOW函数用于返回当前日期和时间,CURDATE函数用于返回当前日期,DATE_FORMAT函数用于格式化日期和时间。它们的语法如下:

NOW()
CURDATE()
DATE_FORMAT(date, format)

例如,假设我们有一个名为orders的表,其中有id、order_date和status三列,我们可以使用NOW函数将当前日期和时间插入到order_date列中:

INSERT INTO orders (order_date, status) VALUES (NOW(), 'processing');

这将向orders表中插入一行数据,其中order_date列的值为当前日期和时间。

18. DATE_ADD函数和DATE_SUB函数

DATE_ADD函数用于在日期上增加一定的时间间隔,DATE_SUB函数用于在日期上减去一定的时间间隔。它们的语法如下:

DATE_ADD(date, INTERVAL value unit)
DATE_SUB(date, INTERVAL value unit)

例如,假设我们有一个名为orders的表,其中有id、order_date和status三列,我们可以使用DATE_ADD函数将order_date列的日期增加一周:

UPDATE orders SET order_date = DATE_ADD(order_date, INTERVAL 1 WEEK);

这将更新orders表中order_date列的数据。

19. DATEDIFF函数

DATEDIFF函数用于计算两个日期之间的天数差。它的语法如下:

DATEDIFF(date1, date2)

例如,假设我们有一个名为orders的表,其中有id、order_date和delivery_date三列,我们可以使用DATEDIFF函数计算两个日期之间的天数差:

SELECT DATEDIFF(delivery_date, order_date) AS delivery_time FROM orders;

这将返回一个新的列delivery_time,其中包含了两个日期之间的天数差。

20. IF函数和CASE函数

IF函数用于根据条件返回不同的值,CASE函数用于根据条件判断返回不同的值。它们的语法如下:

IF(condition, value_if_true, value_if_false)
CASE WHEN condition THEN value WHEN condition THEN value ELSE value END

例如,假设我们有一个名为students的表,其中有id、name和score三列,我们可以使用IF函数根据学生的分数判断其等级:

SELECT name, score, IF(score >= 90, 'A', IF(score >= 80, 'B', IF(score >= 70, 'C', 'D'))) AS grade FROM students;

这将返回一个新的列grade,其中包含了学生的等级。

21. MIN函数和MAX函数

MIN函数用于计算表中某列的最小值,MAX函数用于计算表中某列的最大值。它们的语法如下:

MIN(expression)
MAX(expression)

例如,假设我们有一个名为products的表,其中有id和price两列,我们可以使用MIN函数和MAX函数计算price列的最小值和最大值:

SELECT MIN(price) AS min_price, MAX(price) AS max_price FROM products;

这将返回一个新的列min_price和max_price,其中包含了price列的最小值和最大值。

22. GROUP_CONCAT函数和GROUP BY子句

GROUP_CONCAT函数用于将某列的值连接成一个字符串,GROUP BY子句用于按照某列的值对结果进行分组。它们的语法如下:

GROUP_CONCAT(expression)
GROUP BY column

例如,假设我们有一个名为orders的表,其中有id、customer_id和product_name三列,我们可以使用GROUP_CONCAT函数和GROUP BY子句按照customer_id对product_name进行分组并将其连接成一个字符串:

SELECT customer_id, GROUP_CONCAT(product_name) AS products_ordered FROM orders GROUP BY customer_id;

这将返回一个新的列products_ordered,其中包含了按照customer_id分组后,每个分组中的product_name连接成的字符串。

对于以上介绍的函数,它们对数据库的计算压力主要取决于数据量的大小和查询的复杂程度。在处理大量数据和复杂查询时,这些函数可能会增加数据库的计算压力。因此,在设计数据库和查询时,需要考虑数据量和查询的复杂性,以优化数据库的性能。

相关推荐

微软宣布将于10月份关闭OneDrive组功能

【巴士数码】微软已经宣布将在今年10月关闭OneDrive的组功能。一年多之前,微软已经关闭了用户在OneDrive当中创建组的功能。大大多数用户会发现共享文件夹是一种合适的替代品,而且由于这一点,O...

玩转Win10任务栏:从基础设置到效率神器的全攻略

一、基础操作:解锁任务栏的「隐藏布局」...

文档以只读模式打开的原因及解决方法

当文档以只读模式打开时,可能由多种原因导致。以下是详细的原因分析与对应解决方法,您可根据实际情况灵活选择操作。一、文件属性设置问题(一)Windows系统在Windows系统中,若文件属性被标记...

Windows系统的优化(windows优化设置)

今天给大家讲一讲系统的图标和一些基本的优化。安装了原版系统之后有很多地方需要优化比如桌面图标小箭头,盾牌,休眠占用内存,关闭通知栏。首先我们打开软件这款软件以前就讲到过就是dism++软件,他可以清理...

Win 10偷偷传送用户隐私至微软(win10设备隐私)

自推出以来Win10不断被揭发盗取用户带宽、泄漏WiFi密码等各式各样的私隐问题,令不少网络专家开始留意Win10还隐藏了多少类似的私隐漏洞。最近再有人发现Win10部分功能静静...

OneDrive逆势下调存储空间,不限量存储被取消

日前,微软在周一晚发布的博客文章中表示,由于部分用户存滥用储存功能,所以该公司将取消不限量OneDrive存储服务。不限量用户的最大存储空间将被下调至1TB,定价为6.99美元,对于已存储较多文件和内...

Win10中那些被微软取消的功能(微软公司从9日起停止对windows8的主流服务支持)

很多用户在使用Win10的时候,都会发现一些在Win7系统中的功能被取消了,有的时候想找也找不到。那么到底是那些过去的功能在Win10中被取消了呢?下面我们就简单梳理一下,并且告诉大家解决的办法。Wi...

微软推Win11 Dev 26200.5570预览版:语音打字上线脏话过滤选项

IT之家4月26日消息,微软公司昨日(4月25日)发布博文,邀请Dev频道的WindowsInsider项目成员,测试适用于Windows1124H2的KB50556...

微软VSCode商店发现9款挖矿恶意插件,已安装超30万次

IT之家4月8日消息,科技媒体bleepingcomputer昨日(4月7日)发布博文,报道称安全专家在微软VSCode扩展商店中,发现了9款伪装成开发工具的恶意插件。这些插...

微软Windows 11开始菜单大改版!(windows 11 开始菜单)

根据最新消息,微软正在对Windows11的开始菜单进行重大改版,这一更新将彻底改变其布局和功能。Windows11的开始菜单将从现有的多栏布局改为单栏可滚动视图,所有固定图标和已安装应用都将集中...

OneDrive无限存储空间取消 免费降至5GB

2015-11-0313:35:06作者:徐鹏北京时间11月3日消息,微软在一篇博客文章中称,将取消OneDrive存储服务的不限量空间,原因是部分用户有滥用问题。OneDrive无限存储空间取消...

省出电脑C盘空间!微软悄悄更新:OneDrive终于能卸载了

快科技3月12日消息,近日,微软悄悄地在官方更新了关闭、禁用、卸载Windows自带软件OneDrive的方法。微软Windows系统自带了很多软件和功能,其中有很多我们可能永远都用不上。但这些软件还...

微软关闭OneDrive新建组群功能(windows关闭onedrive)

微软的OneDrive云端储存服务能够让你创建组群(Group),这样当你和团队成员共同从事一个项目的时候能够通过云端协作提升效率,并且组群的文档储存空间还将同你标准的OneDrive分割独立开来。不...

微软为何取消OneDrive无限制容量存储?被75TB占用吓坏

那么为什么微软会取消Office365的无限OneDrive存储呢?“自推出Office365订阅无限制存储服务以来,一小部分用户开始备份多台PC设备,存储众多电影收藏合集和DVR录像。在某些情况下...

Win11必关的5个设置!关闭后电脑流畅到起飞,操作简单不藏私!

Windows11虽然界面炫酷,但默认设置中隐藏了不少“拖慢电脑”的坑!尤其是老电脑用户,用久了卡顿、开机慢、反应迟钝……其实只需关闭几个鸡肋功能,就能让电脑提速50%以上!...

取消回复欢迎 发表评论: