Mysql基础笔记3

ORDER BY 对查询结果排序:SELECT *FROM tbl_name ORDER BY col_name ASC/DESC;也可以按照多个字段排序。
LIMIT限制显示条数:LIMIT 显示条数,LIMIT 偏移量 显示条数,SELECT *FROM cms_user LIMIT N;该语句可以应用到分页显示中。
ORDER BY和LIMIT也可应用于更新或删除记录,但此时LIMIT不能带有偏移量。
内连接查询:JOIN/CROSS JOIN/INNER JOIN,通过ON连接条件,显示两个表中符合选择条件的记录。SELECT tbl_name1.col_name1,…,tbl_name2.col_name1 FROM tbl_name1 JOIN/CROSS JOIN/INNER JOIN tbl_name2 ON tbl_name1.col_name2 = tbl_name2.col_name2;
外连接查询:左外连接:LEFT [OUTER] JOIN,显示左表的全部记录和右表符合连接条件的记录。右外连接:RIGHT [OUTER] JOIN,显示右表的全部记录以及左表符合条件的记录。SELECT tbl_name1.col_name1,…,tbl_name2.col_name1 FROM tbl_name1 LEFT JOIN/RIGHT JOIN tbl_name2 ON tbl_name1.col_name2 = tbl_name2.col_name2;当没有符合条件的记录时用NULL填充。
外键:保证数据的一致性和完整性,数据表的存储引擎为InnoDB。创建外键:FOREIGN KEY (子表中的col_name) REFERENCES 父表tbl_name(col_name);或加上外键名称:CONSTRAINT 外键名称 FOREIGN KEY(子表中的col_name) REFERENCES 父表tbl_name(col_name);删除外键:ALTER TABLE 子表tbl_name DROP FOREIGN KEY 外键名称;添加外键:ALTER TABLE 子表tbl_name ADD CONSTRAINT 外键名称 FOREIGN KEY(子表中的col_name) REFERENCES 父表tbl_name(col_name);
外键约束参照操作:默认为RESTRICT/NO ACTION模式,即拒绝对父表的删除或更新操作。CASCADE级联:从父表中更新或删除行则自动更新或删除子表中匹配的行。SET NULL:从父表中更新或删除行,则设置子表中的外键列为NULL,如果使用该选项,必须保证子表列没有指定NOT NULL。FOREIGN KEY(子表中的col_name) REFERENCES 父表tbl_name(col_name) ON DELETE CASCADE/SET NULL ON UPDATE CASCADE/SET NULL;
联合查询:UNION:去掉相同的记录,UNION ALL:简单合并到一起。SELECT col_name1 FROM tbl_name1 UNION/UNION ALL SELECT col_name1 FROM tbl_name2;
子查询:使用IN/NOT IN,由内向外,SELECT 子表中的col_name1,子表中的col_name2,… FROM 子表tbl_name WHERE 子表中的col_name3 IN/NOT IN (SELECT 父表中的col_name FROM 父表tbl_name);使用比较运算符的子查询:SELECT 子表中的col_name1,子表中的col_name2,… FROM 子表tbl_name WHERE 子表中的col_name3 >= (SELECT 父表中的col_name FROM 父表tbl_name);使用[NOT]EXIST的子查询:SELECT 子表中的col_name1,子表中的col_name2,… FROM 子表tbl_name WHERE 子表中的col_name3 EXISTS/NOT EXISTS (SELECT 父表中的col_name FROM 父表tbl_name);使用ANY/SOME/ALL子查询:SELECT 子表中的col_name1,子表中的col_name2,… FROM 子表tbl_name WHERE 子表中的col_name3 >/>=/</<=ANY/SOME/ALL (SELECT 父表中的col_name FROM 父表tbl_name);
将查询结果写入数据表中INSERT [INTO] tbl_name1 [col_name,…] SELECT col_name,… FROM tbl_name2;需保持字段数量一致。创建数据表同时将查询结果写入到数据表:CREATE TABLE [IF NOT EXISTS] tbl_name1()SELECT col_name,… FROM tbl_name2;该语句只有字段名称一致时才会替代。
正则表达式查询:REGEXP ‘匹配方式’,SELECT FROM tbl_name WHERE col_name RECEXP’匹配方式’,常用的匹配方式有,’’:匹配字符船开始部分,’$’:匹配字符船开始部分,’.’:代表字符串中任意一个字符,包括回车和换行,[字符集合]:匹配字符集合中的任何一个集合,[字符集合]:匹配除字符集合以外的任何一个集合,s1|s2|s3:匹配s1,s2,s3中的任何一个字符串,‘’:代表0个,1个或多个其前的字符,’+’:代表1个或多个其前的字符,string{N}:字符串出现N次,string{M,N}:字符串至少出现M次,最多出现N次。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值