mysql知识点汇总


下期出sql高级部分

在MySQL中,可以使用 ALTER TABLE 命令来添加、修改或删除列。

-- 添加列
ALTER TABLE table_name ADD COLUMN column_name column_definition;

-- 修改列
ALTER TABLE table_name MODIFY COLUMN column_name column_definition;

-- 删除列
ALTER TABLE table_name DROP COLUMN column_name;


在MySQL中,可以为列设置默认值。

ALTER TABLE table_name ALTER COLUMN column_name SET DEFAULT default_value;


在MySQL中,可以重命名表。

ALTER TABLE table_name RENAME TO new_table_name;


在MySQL中,可以创建临时表来存储一些临时数据。

CREATE TEMPORARY TABLE temp_table (column1 datatype, column2 datatype, ...);


在MySQL中,可以使用 UNION ALL 操作符将两个或多个SELECT语句的结果集合并起来。

SELECT column1, column2, ... FROM table1
UNION ALL
SELECT column1, column2, ... FROM table2;


在MySQL中,可以使用 COUNT 函数来计算表中的记录数。

SELECT COUNT(*) FROM table_name;


在MySQL中,可以使用 MAX 函数来计算列中的最大值。

SELECT MAX(column_name) FROM table_name;


在MySQL中,可以使用 MIN 函数来计算列中的最小值。 



SELECT MIN(column_name) FROM table_name;


在MySQL中,可以使用 AVG 函数来计算列中的平均值。

SELECT AVG(column_name) FROM table_name;


在MySQL中,可以使用 SUM 函数来计算列中的总和。

SELECT SUM(column_name) FROM table_name;


在MySQL中,可以使用 GROUP BY 子句来对结果集进行分组。

SELECT column1, SUM(column2) FROM table_name GROUP BY column1;


在MySQL中,可以使用 HAVING 子句来过滤 GROUP BY 子句的结果集。

SELECT column1, SUM(column2) FROM table_name GROUP BY column1 HAVING SUM(column2) > 100;


在MySQL中,可以使用 DISTINCT 关键字来去除重复的记录。

SELECT DISTINCT column1, column2, ... FROM table_name;


在MySQL中,可以使用 IN 操作符来查询某些特定值。

SELECT column1, column2, ... FROM table_name WHERE column1 IN (value1, value2, ...);


在MySQL中,可以使用 BETWEEN 操作符来查询某个范围内的值。

SELECT column1, column2, ... FROM table_name WHERE column1 BETWEEN value1 AND value2;


在MySQL中,可以使用 LIKE 操作符来查询与指定模式匹配的值。

SELECT column1, column2, ... FROM table_name WHERE column1 LIKE pattern;


在MySQL中,可以使用 CONCAT 函数来连接两个或多个字符串。

SELECT CONCAT(column1, column2) FROM table_name;


在MySQL中,可以使用 SUBSTRING 函数来截取字符串。

SELECT SUBSTRING(column1, start_position, length) FROM table_name;


在MySQL中,可以使用 REPLACE 函数来替换字符串中的子串。

SELECT REPLACE(column1, old_value, new_value) FROM table_name;


在MySQL中,可以使用 IF 函数来分支计算。

SELECT IF(column1 > 10, 'large', 'small') FROM table_name;


在MySQL中,可以使用 CASE 函数来实现复杂的逻辑分支。

SELECT CASE WHEN column1 > 10 THEN 'large' ELSE 'small' END FROM table_name;


在MySQL中,可以使用 DATENAME 函数来提取日期和时间的部分。

SELECT DATENAME('month', column1) FROM table_name;


在MySQL中,可以使用 DATEADD 函数来对日期和时间进行加法操作。

SELECT DATEADD(day, 7, column1) FROM table_name;


在MySQL中,可以使用 DATEDIFF 函数来计算两个日期之间的时间差。

SELECT DATEDIFF(day, start_date, end_date) FROM table_name;


在MySQL中,可以使用 DATEPART 函数来获取日期和时间的部分。

SELECT DATEPART(year, column1) FROM table_name;


在MySQL中,可以使用 GETDATE 函数来获取系统日期和时间。

SELECT GETDATE();


在MySQL中,可以使用 CAST 函数来将数据类型转换为另一种类型。

SELECT CAST(column1 AS varchar(10)) FROM table_name;


在MySQL中,可以使用 COALESCE 函数来获取一组值中的第一个非空值。

SELECT COALESCE(column1, column2, column3) FROM table_name;


在MySQL中,可以使用 NULLIF 函数来将两个值进行比较,如果相等则返回NULL。

SELECT NULLIF(expression1, expression2) FROM table_name;


在MySQL中,可以使用 ISNULL 函数来检查是否为NULL。

SELECT column1 FROM table_name WHERE ISNULL(column1);


在MySQL中,可以使用 DATE 函数来将日期字符串转换为DATE类型。

SELECT DATE('2022-05-20') FROM table_name;


在MySQL中,可以使用 NOW 函数来获取当前日期和时间。

SELECT NOW() FROM table_name;


在MySQL中,可以使用 ROUND 函数来四舍五入数字。

SELECT ROUND(column1, 2) FROM table_name;


在MySQL中,可以使用 CEILING 函数来向上取整数字。

SELECT CEILING(column1) FROM table_name;


在MySQL中,可以使用 FLOOR 函数来向下取整数字。

SELECT FLOOR(column1) FROM table_name;


在MySQL中,可以使用 RAND 函数来生成随机数。

SELECT RAND() FROM table_name;


在MySQL中,可以使用 ASCII 函数来获取字符的ASCII码。

SELECT ASCII('A') FROM table_name;


在MySQL中,可以使用 CHAR 函数来将ASCII码转换为字符。

SELECT CHAR(65) FROM table_name;


在MySQL中,可以使用 HEX 函数来将二进制数据转换为十六进制格式。

SELECT HEX(column1) FROM table_name;


在MySQL中,可以使用 UNHEX 函数来将十六进制格式转换为二进制数据。

SELECT UNHEX(column1) FROM table_name;


在MySQL中,可以使用 LENGTH 函数来获取字符串的长度。

SELECT LENGTH(column1) FROM table_name;


在MySQL中,可以使用 SUBSTR 函数来获取字符串的子串。

SELECT SUBSTR(column1, start_position, length) FROM table_name;


在MySQL中,可以使用 TRIM 函数来去除字符串的前导和后缀空格。

SELECT TRIM(column1) FROM table_name;


在MySQL中,可以使用 LTRIM 函数来去除字符串的前导空格。

SELECT LTRIM(column1) FROM table_name;


在MySQL中,可以使用 RTRIM 函数来去除字符串的后缀空格。

SELECT RTRIM(column1) FROM table_name;


在MySQL中,可以使用 REPLACE 函数来替换字符串中的子串。

SELECT REPLACE(column1, old_value, new_value) FROM table_name;


在MySQL中,可以使用 CONCAT_WS 函数来连接一组字符串,并使用指定分隔符。

SELECT CONCAT_WS(',', column1, column2, column3) FROM table_name;


在MySQL中,可以使用 DAY 函数来获取日期的天份。

SELECT DAY(column1) FROM table_name;


在MySQL中,可以使用 MONTH 函数来获取日期的月份。

 

MySQL 是一个关系型数据库管理系统(RDBMS)。
MySQL 可以在多个操作系统上运行,包括 Windows、Linux 和 Mac OS 等。
MySQL 使用 SQL 语言进行数据的操作。
MySQL 的数据存储在表中。
数据表是由行和列组成的,每一行代表一条记录,每一列代表一个字段。
主键是用来唯一标识表中每一条记录的一列或多列。
外键是一个表中的一列,它指向另一个表中的主键。
索引是提高MySQL数据检索速度的一种方法,可以使用多种类型的索引。
数据库是由一个或多个数据表组成的。
MySQL提供了许多存储引擎,包括 MyISAM、InnoDB、Memory 等等。
MyISAM 存储引擎提供了快速的读取操作,但不支持事务。
InnoDB 存储引擎提供了事务支持,但会减慢读取操作的速度。
MEMORY 存储引擎使用内存来存储数据,速度非常快,但是数据在服务器关闭后会丢失。
MySQL 支持许多数据类型,包括整数、浮点数、日期和字符串等等。
CHAR 和 VARCHAR 是最常见的字符串类型。
TINYINT、SMALLINT、MEDIUMINT 和 INT 等整数数据类型是 MySQL 中常用的整数类型。
FLOAT 和 DOUBLE 是 MySQL 中常用的浮点数类型。
MySQL 的文本类型包括 TEXT、 MEDIUMTEXT 和 LONGTEXT。
MySQL 的日期和时间类型有 DATE、TIME、DATETIME 和 TIMESTAMP。
MySQL 通过 ALTER TABLE 命令来修改表的结构。
MySQL 可以通过 CREATE INDEX 命令来创建索引。
MySQL 可以通过 DROP INDEX 命令来删除索引。
MySQL 中的 UNION 操作用于合并两个或多个 SELECT 语句的结果集。
MySQL 中的 JOIN 操作用于在多个表之间进行联接。
LEFT JOIN 是 MySQL 中最常用的 JOIN 类型。
在 MySQL 中,可以使用 WHERE 子句来过滤 SELECT 语句的结果。
MySQL 提供了 GROUP BY 子句,用于按照一个或多个列对 SELECT 语句的结果进行分组。
MySQL 提供了 HAVING 子句,用于过滤 GROUP BY 子句返回的结果集。
MySQL 中可以使用 ORDER BY 子句来对 SELECT 语句返回的结果进行排序。
MySQL 中可以使用 LIMIT 子句来限制 SELECT 语句返回的结果集的数量。
MySQL 中提供了 CASE 子句,用于根据条件选择不同的语句块。
MySQL 可以使用 TRIGGER 实现在插入、更新或删除数据时执行一些操作。
MySQL 中的存储过程和函数是一些预编译的 SQL 语句,可以在需要时调用执行。
在 MySQL 中,可以使用视图来简化复杂的查询,隐藏数据中的敏感信息。
MySQL 的事务是一个操作序列,要么全部执行,要么全部回退。
MySQL 的 ACID(原子性、一致性、隔离性、持久性)特性确保了事务的正确性和完整性。
MySQL 支持全文搜索功能,可以在文本数据中进行关键词搜索。
MySQL 可以使用存储过程和函数来实现递归查询。
导出 MySQL 表数据可以使用 SELECT INTO OUTFILE 命令,将数据保存到文件中。
导入 MySQL 数据可以使用 LOAD DATA INFILE 命令,从文件中加载数据。
MySQL 支持备份和恢复操作,可以使用 mysqldump 命令来备份数据库。
MySQL 的设定优化,包括修改 MySQL 缓存、更改存储引擎和优化 SQL 查询等等。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值