【MySql】MySql之语句

19 篇文章 0 订阅
      WHERE

将where子句添加到select语句中,可以实现按条件选取数据。

where子句也可以运用于 SQL delete或者 update命令

可以使用and或者or指定一个或多个条件

多表查询可以使用,分割,并使用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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值