开发者社区> jeanron100> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

MySQL特有的SQL语句 第一弹

简介: 关于SQL,我们总是会有无穷无尽相关的话题,有时候碰到了一些觉得不错的SQL功能会标记下来,好记性不烂烂笔头,回头来看,自己也收集了不少的点子,但是从整体来看,可能仅仅是一瓢水而已。
+关注继续查看
关于SQL,我们总是会有无穷无尽相关的话题,有时候碰到了一些觉得不错的SQL功能会标记下来,好记性不烂烂笔头,回头来看,自己也收集了不少的点子,但是从整体来看,可能仅仅是一瓢水而已。大家有好的想法也欢迎留言,一起总结完善一下。

  首先MySQL里面的SQL标准可以参考下面的表格,我们今天想总结的是MySQL特有的SQL语句。

640?wxfrom=5&wx_lazy=1

  我们可以化繁为简,把所有的SQL都按照增删改查的四个维度来对待,只是有些语法的含义更广一些,比如增,创建表我们也算增的范畴,改,修改字段也算是改的范畴。

create语句

如果要复制表结构信息,下面的语句真是简洁有力,会把表test1的结构复制出来。

   create table test like test1;

select into语句

  select into语句可以很快的从表里取出数据,快速构造出一个表来。

SELECT vale1, value2 into Table2 from Table1
   这里会要求目标表Table2不存在,因为在插入时会自动创建表Table2

insert语句中的表达式

MySQL里的insert语句还是很丰富的。比如下面的动态值,设置表达式的方式,MySQL就有自己的口味。

   INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);  

 --ok
    INSERT INTO tbl_name (col1,col2) VALUES(col2*2,15);  

--wrong

insert语句

MySQL支持的特有的insert语句,下面的第一种是mysqldump导出的语句格式,这种方式比较清晰,相比多条SQL语句效果要好太多。

   INSERT INTO table (a, b, c) VALUES (1,2,3) ,(2,3,4);

下面的语句看起来比较特别,解析MySQL binlog会发现,里面的insert语句是这个样子的。

  INSERT INTO table SET a=1, b=2, c=3;


drop语句

MySQL里面的drop语句还是蛮有特点,它不会像Oracle那样可以单独删除索引,删除是始终要和表关联起来,这样想来和IOT的特点还是蛮对味的。

如果你直接删除一个索引,就会抛出如下的错误。

    ?Drop index ind_account_id2;

    ?ERROR 1064 (42000):

  可以使用如下的方式:

drop index ind_account_id2 on t_user_login_record;

Query OK, 0 rows affected (0.01 sec)

Records: 0  Duplicates: 0  Warnings: 0

  或者是用比较经典的写法:

alter table t_user_login_record drop index account;


级联删除

MySQL里面支持级联删除,下面的语句会级联删除数据,这一点Oracle目前还是不支持这种方式的。

delete A, B from A, B where A.id = B.aid



级联更新

update A, B set A.a = a1, B.b = b1 where A.id = B.aid


change modify

change,modify用法有些相似,但是细究起来还是有自己适合的使用场景,比如与修改字段b的类型或者属性,change还更适合于修改字段名称,修改数据类型modify更加直接一些。

ALTER TABLE t1 CHANGE b b BIGINT NOT NULL;
ALTER TABLE t1 MODIFY b BIGINT NOT NULL;

replace语句

 MySQL里面的replace语句还是很有特色的,和Oracle里面的merge有一拼,它支持两种模式,数据值和子查询的方式


replace into x values(...)

或者

replace into x select * from y

renmae语句

 这个功能很可能被大家忽略,但是实际上这个功能很实用,比如要把一个表清理表,如果你把它归档到一个历史数据库中而暂时不清理数据,这种方式就很快捷。

rename table testsync.t_fund_info to test.t_user_login_record;

Query OK, 0 rows affected (0.05 sec)

limit语法

  limit的使用算是MySQL中很经典的使用方法了,它也支持多种模式。

比如只返回第2条结果

select * from x

limit 2

返回第2条到第12条的结果

or limit 2, 10


order by的妙用

如果下面的数据需要排序,

select *from test order by name;
+------+------+
| id   | name |
+------+------+
|    1 | aa1  |
|    3 | aa10 |
|    4 | aa11 |
|    2 | aa2  |
+------+------+
我们希望是按照aa1,aa2,aa10,aa11的顺序来显示,直接这样写就可以了。

select *from test order by name+0;
+------+------+
| id   | name |
+------+------+
|    1 | aa1  |
|    2 | aa2  |
|    3 | aa10 |
|    4 | aa11 |
+------+------+

特有的函数

如果需要截取一下字符串,比如截取出数字,就有很多种实现方式。

比如下面的方式就可行。

mysql> select replace('123456G', right('123456G',1), '');

+--------------------------------------------+

| replace('123456G', right('123456G',1), '')

|+--------------------------------------------+

| 123456                                    

|+--------------------------------------------+

或者是使用cast来过滤

> select cast('123124aabc' as unsigned); 

+--------------------------------+

| cast('123124aabc' as unsigned) |

+--------------------------------+

|                         123124 |

+--------------------------------+

1 row in set, 1 warning (0.01 sec)


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Windows环境下安装及配置MySQL
本文主要讲解在Windows环境下MySQL的安装、配置
3929 0
关于windows server 2019安装mysql 8.0 版本报错服务没有及时响应启动或控制请求
windows server 2019安装mysql 8.0 版本报错服务没有及时响应启动或控制请求
354 0
centos安装mysql
centos安装mysql
112 0
Docker 介绍 四 安装 mysql ,tomcat
Docker 介绍 四 安装 mysql ,tomcat
110 0
mysql 5.7 二进制安装
mysql 5.7 二进制安装
117 0
mysql读写分离1 -- mysql安装
该系列从计划分为一下内容: 1. mysql读写分离1 -- mysql安装 2. mysql读写分离1 -- 主从复制 3. mysql读写分离1 -- 读写分离 ...
454 0
+关注
jeanron100
Oracle ACE,《Oracle DBA工作笔记》作者 现就职于国内某互联网公司,擅长数据管理,数据迁移,性能优化,目前专注于开源技术,运维自动化和性能优化。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
MySQL 5.7让优化更轻松
立即下载
MySQL表和索引优化实战
立即下载
PostgresChina2018_张启程_为什么我们抛弃MongoDB和MySQL,选择PgSQL
立即下载