【MySql】MySql之语句
WHERE
将where子句添加到select语句中,可以实现按条件选取数据。
l where子句也可以运用于 SQL的 delete或者 update命令
l 可以使用and或者or指定一个或多个条件
l 多表查询可以使用,分割,并使用where语句来设定查询条件
l 使用主键来作为 WHERE 子句的条件查询是非常快速的
操作符 |
描述 |
实例 |
= |
等号,检测两个值是否相等,如果相等返回true |
(A = B)返回false。 |
<>, != |
不等于,检测两个值是否相等,如果不相等返回true |
(A != B)返回 true。 |
> |
大于号,检测左边的值是否大于右边的值,如果左边的值大于右边的值返回true |
(A > B)返回false。 |
< |
小于号,检测左边的值是否小于右边的值,如果左边的值小于右边的值返回true |
(A < B)返回 true。 |
>= |
大于等于号,检测左边的值是否大于或等于右边的值,如果左边的值大于或等于右边的值返回true |
(A >= B)返回false。 |
<= |
小于等于号,检测左边的值是否小于于或等于右边的值,如果左边的值小于或等于右边的值返回true |
(A <= B)返回 true。 |
注意:MySQL的 WHERE 子句的字符串比较是不区分大小写的。你可以使用 BINARY关键字来设定 WHERE 子句的字符串比较是区分大小写的。
UPDATE 更新
l 你可以同时更新一个或多个字段。
l 你可以在 WHERE 子句中指定任何条件。
l 你可以在一个单独表中同时更新数据。
update table_tb1 set tb1_author='123' wheretb1_title = '学习 MySQL';
可实现字段追加
update table_tb1 set tb1_author=concat(tb1_author,'45678')where tb1_title = '学习 MySQL';
DELETE 语句
l 如果没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。
l 你可以在 WHERE 子句中指定任何条件
l 您可以在单个表中一次性删除记录。
delete from table_tb1 where tb1_author ='12345678';
LIKE 语句
l 可以在 WHERE 子句中指定任何条件。
l 可以在 WHERE 子句中使用LIKE子句。
l 可以使用LIKE子句代替等号 =。
l LIKE 通常与 % 一同使用,类似于一个元字符的搜索。
l 可以使用 AND 或者 OR 指定一个或多个条件。
l 可以在 DELETE 或 UPDATE 命令中使用 WHERE...LIKE 子句来指定条件。
select * from table_tb1 where tb1_titlelike '学习%';
UNION操作符
MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。
UNION 后面加ALL可返回所有结果集,包含重复数据。
UNION ALL
ORDER BY 子句
l 可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
l 可以设定多个字段来排序。
l 可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列。默认情况下,它是按升序排列。
l 可以添加 WHERE...LIKE 子句来设置条件。
默认升序
select * from table_tb1 order by tb1_date
降序
select * from table_tb1 order by tb1_datedsc
GROUP BY 子句
GROUP BY 语句根据一个或多个列对结果集进行分组。
在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。
JOIN 子句
JOIN 按照功能大致分为如下三类:
l INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
l LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
l RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
MySQL的INNER JOIN(也可以省略 INNER 使用 JOIN,效果一样),表示去两个表共有的部分
MySQL left join 与 join 有所不同。 MySQLLEFT JOIN 会读取左边数据表的全部数据,即便右边表无对应数据,没有则为null。
MySQL RIGHT JOIN 会读取右边数据表的全部数据,即便左边边表无对应数据。
NULL 处理
当提供的查询条件字段为 NULL时,MySQL提供了三大运算符:
l IS NULL: 当列的值是 NULL,此运算符返回 true。
l IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
l <=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true。
SELECT * FROM runoob_test_tbl WHERErunoob_count IS NULL;
正则表达式
和like相似,MySQL中使用REGEXP操作符来进行正则表达式匹配。
下表中的正则模式可应用于 REGEXP操作符中。
模式 |
描述 |
^ |
匹配输入字符串的开始位置。 |
$ |
匹配输入字符串的结束位置。 |
. |
匹配除 "\n"之外的任何单个字符。要匹配包括 '\n' 在内的任何字符,请使用象 '[.\n]' 的模式。 |
[...] |
字符集合。匹配所包含的任意一个字符。例如, '[abc]'可以匹配 "plain" 中的 'a'。 |
[^...] |
负值字符集合。匹配未包含的任意字符。例如, '[^abc]'可以匹配 "plain" 中的'p'。 |
p1|p2|p3 |
匹配 p1或 p2 或 p3。例如,'z|food' 能匹配 "z" 或 "food"。 |
* |
匹配前面的子表达式零次或多次。例如,zo*能匹配 "z" 以及 "zoo"。* 等价于{0,}。 |
+ |
匹配前面的子表达式一次或多次。例如,'zo+'能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。 |
{n} |
n是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。 |
{n,m} |
m和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。 |
例如
查找name字段中以'st'为开头的所有数据:
mysql> SELECT name FROM person_tbl WHEREname REGEXP '^st';
查找name字段中以'ok'为结尾的所有数据:
mysql> SELECT name FROM person_tbl WHEREname REGEXP 'ok$';
查找name字段中包含'mar'字符串的所有数据:
mysql> SELECT name FROM person_tbl WHEREname REGEXP 'mar';
查找name字段中以元音字符开头或以'ok'字符串结尾的所有数据:
mysql> SELECT name FROM person_tbl WHEREname REGEXP '^[aeiou]|ok$';
ALTER 命令
1) 可以配合删除、添加或修改表列
删除列
mysql> ALTER TABLE testable_tbl DROP columnName_1;
添加列
mysql> ALTER TABLE testable_tbl ADDcolumnName_2 INT;
ADD 默认添加到所有列的末尾,如果想控制位置,可以使用FIRST或者AFTER关键字
FIRST 设定为第一列;AFTER 设定位于某个列之后。
2) 修改列类型及名称
可以在ALTER命令中使用 MODIFY 或 CHANGE 子句,修改类型及名称。
l 修改指定列的类型
mysql> ALTER TABLE testalter_tbl(表名) MODIFY c(指定的列名)CHAR(10)(新的类型);
ALTER TABLE testalter_tbl MODIFY j BIGINTNOT NULL DEFAULT 100; #指定字段 j 为 NOT NULL 且默认值为100
l 修改指定列的名称及类型
mysql> ALTER TABLE testalter_tbl(表名) CHANGE i(指定的列名) j (新的列名)BIGINT(新的类型);
1) 修改字段默认值
ALTER TABLEtestalter_tbl ALTER i SET DEFAULT 1000;
删除默认值
ALTER TABLEtestalter_tbl ALTER i DROP DEFAULT;
2) 修改表名
mysql> ALTERTABLE testalter_tbl RENAME TO alter_tbl;