MySQL基础实例-阿里云开发者社区

开发者社区> 吟风_骋> 正文

MySQL基础实例

简介: 总结了一些个人觉得比较常用且重要的mysql sql语句基础操作,不全待续
+关注继续查看

我们可以对多个column 进行排序
image

DATE_FORMAT(DATE,format) 函数,可以让日期以指定格式输出
SELECT name, birth, DATE_FORMAT(now(),"%Y-%m-%d %T") as curDate FROM pet;
image

不能在NULL 列上做算数比较,不起作用
SELECT 1 = NULL, 1 <> NULL, 1 < NULL, 1 > NULL;
image

查询具体以特定字符串开头,用REGEXP_LIKE()函数, 并且表达式以“^”符号开始
SELECT * FROM pet WHERE REGEXP_LIKE(name, '^bu');
image

当然,有从开头查询,就有从结尾匹配查询,如查找以“fy”结尾的name,需要用到‘$’符号
SELECT * FROM pet WHERE REGEXP_LIKE(name, 'fy$');
image
REGEXP_LIKE(name, 'w') 匹配包含‘w’的字符串
REGEXP_LIKE(name, '^.{5}$') 匹配长度为5的字符串

Group by 可以针对多列进行分组行为
SELECT species, sex, COUNT(*) FROM pet GROUP BY species, sex;
image

@@global 可以进行全局访问
SELECT @@global.sql_mode;
set @@global.sql_mode ='’;

SELECT DATABASE(); 显示当前使用的数据库
SHOW TABLES; 当前库包含的表
DESCRIBE pet; 显示表pet的具体表描述

用户自定义变量
SELECT @min_weight:=MIN(weight),@max_weight:=MAX(weight) FROM pet;
SELECT * FROM pet WHERE weight=@min_weight OR weight=@max_weight;
image

连接mysql数据库
shell> mysql -u root -p --execute="SELECT User, Host FROM mysql.user"
Enter password:

连接mysql server,利用 SHOW BINARY LOGS; 可以查看当前所有binlog的二进制文件
image

mysqlbinlog 利用--hexdump 参数可以将二进制日志内容生成十六进制dump
如已配置mysqlpath,binlog.000001 文件在目录C:installmysql-8.0.16-winx64data 下
执行命令 C:installmysql-8.0.16-winx64data>mysqlbinlog --hexdump binlog.000001
image

登录msyql 终端,
日志文件路径show variables like 'general_log_file';
image
错误日志show variables like 'log_error';
image
慢查询日志文件show variables like 'slow_query_log_file';
image

可以告诉mysqlbinlog为行事件禁用BINLOG语句
先执行sql: update pet set sex='f' where id=9; 看看log里面干了什么事
mysqlbinlog -v --base64-output=DECODE-ROWS binlog.000001
image

显示log文件中慢查询的语句:shell> mysqldumpslow [options] [log_file ...]
如 mysqldumpslow -v binlog.000001

查看当前mysql运行的一些变量,可以执行命令 mysql> SHOW VARIABLES;
查看当前mysql运行的一些统计和状态指标,执行命令 mysql> SHOW STATUS;

SQL modes 影响Mysql支持的语法以及数据验证。它使得在不同环境使用mysql或者和其他数据库服务变得更加容易。
Sql mode很重要,比如一些 mode是至关重要的,拿 strict mode 来说
先查看 SELECT @@global.sql_mode;
image

修改sql mode 来支持严格的校验,如截图
image

And条件的优化
先执行 show index from pet; 查看索引
image

explain select * from pet where sex='f' and card_no > 201912020001;
image
使用了card_no_name 的索引,type为范围查询,共找到8行数据。
可以清晰看到,where 后的条件以“and” 连接,条件会根据索引等进行优先过滤,不受条件在and的位置顺序影响。
另外,range compare 范围比较,根据情况进行具体分析,也会走索引查询。

几个比较常用且特殊的操作符Comparison Operators
<=> NULL-safe equal to operator
!=, <> Not equal operator
NOT LIKE Negation of simple pattern matching
IS NOT NULL 判断不是NULL 返回1

mysql> SELECT 1 <=> 1, NULL <=> NULL, 1 <=> NULL;

    -> 1, 1, 0

mysql> SELECT 1 = 1, NULL = NULL, 1 = NULL;

    -> 1, NULL, NULL

mysql> SELECT 1 IS NOT NULL, 0 IS NOT NULL, NULL IS NOT NULL;

    -> 1, 1, 0

流控制方法
mysql> SELECT CASE 1 WHEN 1 THEN 'one' WHEN 2 THEN 'two' ELSE 'more' END;

    -> 'one'

mysql> SELECT IF(1<2,'yes','no');

    -> 'yes'

mysql> SELECT IF(STRCMP('test','test1'),'no','yes');

    -> 'no'

IFNULL(expr1,expr2)
If expr1 is not NULL, IFNULL() returns expr1; otherwise it returns expr2.

mysql> SELECT IFNULL(NULL,10);

    -> 10

查看mysql 引擎
mysql> SHOW ENGINES;
mysql> SELECT * FROM INFORMATION_SCHEMA.ENGINES;

停止自动提交
SET autocommit=0;

LOCK INSTANCE FOR BACKUP
UNLOCK INSTANCE
LOCK INSTANCE FOR BACKUP 获取一个实例级备份锁,该锁允许在联机备份期间使用DML,同时防止可能导致不一致快照的操作

Index
索引分为聚簇索引和二级索引
为什么聚簇索引查询快,是因为索引搜索直接到存有数据的叶子结点。

二级索引是如何关联聚簇索引?
二级索引上的每个记录都包含了行数据的主键以及二级索引指定的列。二级索引用此主键去聚簇索引上搜索数据。当然,因为二级索引存储primary Key, 所以key越短越好。

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

相关文章
OceanBase数据库漫谈
从开发视角、运维视角、数据拆分漫谈OceanBase
22 0
node+mysql+express接口开发数据库连接池
node+mysql+express接口开发数据库连接池
18 0
node+express controller
Node + Express Controller
14 0
教育培训机构使用阿里云无影桌面优缺点
配置灵活,GPU满足设计产品线,价格低廉,随开随用。
27 0
Node + Express + MySQL 接口开发完整案例
Node + Express + MySQL 接口开发完整案例
20 0
【mockito】单元测试之mockito简单使用
项目使用的是springmvc+mybatis 开发; mock包为 mockito-all;虽然也引用了powermock,但截至目前,还未使用到;如果使用到后续再补相关笔记。
15 0
工商银行实时大数据平台建设历程及展望
中国工商银行大数据平台负责人袁一在 FFA 2021 的分享
29 0
ACP实战特训营RDS(DAY3)
要点记录 1. PolarDB的基本概念 1.1、对比单机数据库优势有哪些:简单易用、极致性能、降低成本、海量存储、安全可靠、快速弹性 1.2 、单机数据库容量瓶颈-单机数据库扩展困难-数据库使用成本过高-分布式数据库应用开发繁琐 2. PolarDB产品系列:集群版-单节点-历史库-多主架构 2.1、集群:一个集群包含一个主节点和多个读节点,最多16个节点,即一个主节点和15个只读节点 2.2、地域:是指物理的数据中心,一般情况下,PolarDB集群应该和ECS实例位于同一地域,以实现最高的访问性能
14 0
浅谈我对DDD领域驱动设计的理解
DDD的全称为Domain-driven Design,即领域驱动设计。下面我从领域、问题域、领域模型、设计、驱动这几个词语的含义和联系的角度去阐述DDD是如何融入到我们平时的软件开发初期阶段的。要理解什么是领域驱动设计,首先要理解什么是领域,什么是设计,还有驱动是什么意思,什么驱动什么。
12 0
面试题:说一说es6新增方法
面试题:说一说es6新增方法
5 0
+关注
吟风_骋
先知先觉富贵一生,不知不觉贫穷一生,惰弱者注定残喘一生!
7
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载