一、数据库操作

创建数据库

语法:

CREATE DATABASE database_name;

删除数据库

删除数据库务必谨慎!因为执行删除命令后,所有数据将消失。

语法:

DROP DATABASE database_name;

选择数据库

语法:

USE database_name;

二、数据表操作

数据类型

数值类型

日期和时间类型

字符串类型

创建数据表

语法:

CREATE TABLE table_name (
    column_name column_type
);

示例:

CREATE TABLE IF NOT EXISTS t_student(
	stu_id INT NOT NULL AUTO_INCREMENT,
    stu_name VARCHAR(100) NOT NULL,
    stu_email VARCHAR(200),
    PRIMARY KEY (stu_id)
);

结果:

MySQL 常用命令手册 增删改查大法-LMLPHP

删除数据表

语法:

DROP TABLE table_name;

插入数据

语法:

INSERT INTO table_name(
    field1, field2, ... fieldN
) VALUES(
    value1, value2, ... valueN
);

#插入多条数据
INSERT INTO table_name(
    field1, field2, ... fieldN
) VALUES(
    valueA1, valueA2, ... valueAN
) VALUES(
	valueB1, valueB2, ... valueBN
);

示例:

INSERT INTO t_student(
	stu_id, stu_name, stu_email
) VALUE (
	10001, 'Tom', '[email protected]'
);

结果:

MySQL 常用命令手册 增删改查大法-LMLPHP

查询数据

语法:

SELECT field1, field2 ...
FROM table_name
[WHERE Clause]
[LIMIT N][OFFSET N]
  • 查询语句中可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。
  • SELECT 命令可以读取一条或者多条记录。
  • 可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
  • 可以使用 WHERE 语句来包含任何条件。
  • 可以使用 LIMIT 属性来设定返回的记录数。
  • 可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0

WHERE 子句

语法:

SELECT field1, field2, ... field2 FROM table_name1, table_name2
[WHERE condition1 [AND [OR]]] condition2 ...
  • 查询语句中可以使用一个或者多个表,表之间使用逗号, 分割,并使用WHERE语句来设定查询条件。
  • 可以在 WHERE 子句中指定任何条件。
  • 可以使用 AND 或者 OR 指定一个或多个条件。
  • WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。
  • WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。

UPDATE 更新

语法:

UPDATE table_name SET field1 = new_value1, field2 = new_value2
[WHERE Clause]
  • 可以同时更新一个或多个字段。
  • 可以在 WHERE 子句中指定任何条件。
  • 可以在一个单独表中同时更新数据。

DELETE 语句

语法:

DELETE FROM table_name
[WHERE Clause]
  • 如果没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。
  • 可以在 WHERE 子句中指定任何条件
  • 可以在单个表中一次性删除记录。

LIKE 子句

描述:

我们知道在 MySQL 中使用 SQL SELECT 命令来读取数据, 同时我们可以在 SELECT 语句中使用 WHERE 子句来获取指定的记录。

WHERE 子句中可以使用等号 = 来设定获取数据的条件,如 "stu_email = '[email protected]'"。

但是有时候我们需要获取 stu_email 字段含有 "com" 字符的所有记录,这时我们就需要在 WHERE 子句中使用 SQL LIKE 子句。

SQL LIKE 子句中使用百分号 %字符来表示任意字符,类似于UNIX或正则表达式中的星号 *****。

如果没有使用百分号 %, LIKE 子句与等号 = 的效果是一样的。

语法:

SELECT field1, field2, ... fieldN
FROM table_name
WHERE field1 LIKE condition1 [AND [OR]] field2 = 'somevalue'
  • 你可以在 WHERE 子句中指定任何条件。
  • 你可以在 WHERE 子句中使用LIKE子句。
  • 你可以使用LIKE子句代替等号 =
  • LIKE 通常与 % 一同使用,类似于一个元字符的搜索。
  • 你可以使用 AND 或者 OR 指定一个或多个条件。
  • 你可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。

UNION

描述:

UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

语法:

SELECT field1, field2, ... fieldN
FROM table_name
[WHERE condition]
UNION [ALL | DESTINCT]
SELECT field2, field2, ... fieldN
FROM table_name
[WHERE condition];
  • filed1, field2, ... fieldN: 要检索的列。
  • table_name: 要检索的数据表。
  • WHERE conditions: 可选, 检索条件。
  • DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。
  • ALL: 可选,返回所有结果集,包含重复数据。

ORDER BY 排序

语法:

SELECT field1, field2, ... fieldN
FROM table_name
ORDER BY field1 [ASC [DESC]], [field2 ...] [ASC [DESC]]
  • 可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
  • 可以设定多个字段来排序。
  • 可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。 默认情况下,它是按升序排列。
  • 可以添加 WHERE...LIKE 子句来设置条件。

GROUP BY 分组

描述:

GROUP BY 语句根据一个或多个列对结果集进行分组。

在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。

语法:

SELECT column_name function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;

JOIN 连接

描述:

  • INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。

    MySQL 常用命令手册 增删改查大法-LMLPHP

  • LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。

MySQL 常用命令手册 增删改查大法-LMLPHP

  • RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。

MySQL 常用命令手册 增删改查大法-LMLPHP

语法

# INNER JOIN
SELECT a.filed1, a.filed2, ... b.filed1, ...
FROM table_name1 a INNER JOIN table_name2 b
ON a.id = b.id;
# LEFT JOIN
SELECT a.filed1, a.filed2, ... b.filed1, ...
FROM table_name1 a LEFT JOIN table_name2 b
ON a.id = b.id;
# RIGHT JOIN
SELECT a.filed1, a.filed2, ... b.filed1, ...
FROM table_name1 a RIGHT JOIN table_name2 b
ON a.id = b.id;

NULL 值处理

我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时,该命令可能就无法正常工作。

为了处理这种情况,MySQL提供了三大运算符:

  • IS NULL: 当列的值是 NULL,此运算符返回 true。
  • IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
  • <=>: 比较操作符(不同于 = 运算符),当比较的的两个值相等或者都为 NULL 时返回 true。

关于 NULL 的条件比较运算是比较特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。

在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 NULL,即 NULL = NULL 返回 NULL 。

MySQL 中处理 NULL 使用 IS NULL 和 IS NOT NULL 运算符。

ALTER 命令

描述:

当我们需要修改数据表名或者修改数据表字段时,需要 ALTER 命令。

删除表字段

ALTER TABLE table_name DROP column_name;

添加表字段

ALTER TABLE table_name ADD column_name datatype;

修改表字段

# MODIFY
ALTER TABLE table_name MODIFY column_name new_datatype;
# CHANGE
ALTER TABLE table_name CHANGE old_column_name new_column_name new_datatype;
02-24 14:32