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

MySQL 第九篇:Mysql 与 ORACLE 开发差异、Mysql 优化

简介: 我把MySQL的内容整理成9篇博客,学完这9篇博客虽不能说能成为大神,但是应付一般中小企业的开发已经足够了,有疑问或建议的欢迎留言讨论。 Mysql 与 ORACLE 开发差异 一、 常用的基本数据类型对比 二、 常用 SQL函数以及其它语法差异 Mysql 优化 一、 数据库设计 a) 适当的违反三大范式。
+关注继续查看

我把MySQL的内容整理成9篇博客,学完这9篇博客虽不能说能成为大神,但是应付一般中小企业的开发已经足够了,有疑问或建议的欢迎留言讨论。

Mysql 与 ORACLE 开发差异

一、 常用的基本数据类型对比

76838d15f95c5994afb59540f1143514ad47c2f1

二、 常用 SQL函数以及其它语法差异

ef4fe316c784120407714e3f8b0b0266f60fc8dd

Mysql 优化

一、 数据库设计

a) 适当的违反三大范式。
b) 适当建立索引。
c) 对表进行水平划分(按照一个周期对表数据进行拆分)。
d) 对表进行垂直划分(对字段内容较长的字段进行拆分到一个新表)。
e) 选择合适的字段类型。能占用字节小的字段就不要去大字段。
f) 文件、图片等二进制的文件使用文件系统存储,不用数据库。数据库中只存储文件路径。
g) 宁可集中批量操作 也不要频繁操作。
h) 合适的引擎选择 mysql 的数据库引擎,innodb,myisam,memory 。Myisam 比innodb 的读速度更快。Innodb 是支持事务。Myisam 不支持事务。

二、SQL 语句优化

a. 使用 EXPLAIN 进行 SQL 语句的执行解析。
b. Mysql 慢 日 志 的 功 能 需 要 去 配 置 文 件 修 改 slow_query_log=/usr/xx.txtlong_query_time=2 单位秒。
c. 查询语句尽量避免全表扫描,在 where order by 等涉及的字段建立索引。
d. 尽量避免在 where 子句中对 null 值进行判断,如果进行 null 判断则会放弃索引查询走全表扫描,解决办法:在 null 字段设置一个默认值来代表无值。
e. 尽量避免在 where 子句中使用!= 或 <>操作符,放弃走索引进行全表扫描,解决办法:改为>= <=。
f. Like 查询,使用’%jame’ 不会走索引,使用’jame%’ 会走索引。
g. 尽量避免在 where 子句中使用 or 来连接条件 不会走索引走全表扫描。解决办法:将两个条件作为两条 sql 语句执行 使用 union all 来进行结果集的整合。
h. In 和 not in 也要少用,会导致全表扫描。
i. 尽量避免在 where 子句中对字段进行表达式的操作,不会走索引会走全表扫描。Num/3=100 修改成 num = 3*100。
j. 尽量避免在 where 子句中使用函数对字段进行操作. Substring(name,1,3)=’xzg’ 修改成name like ‘xzg%’。
k. 不要在 Where 字句的 =号的左边进行函数或者其他表达式的运算,数据库可能就无法正确使用索引。
l. 使用 exists 来代替 in。
m. 在代码中尽量避免使用 select * from 而是列出准确的字段名。
n. 尽量避免使用游标。
o. 数据较少的表 尽量让他走全表扫描。

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

相关文章
mysql三种安装方式
mysql三种安装方式
46 0
docker 安装 mysql 5.7
docker 安装 mysql 5.7
369 0
SaltStack安装Apache/Mysql/PHP部署Wordpress
SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、监控等功能,基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。 SaltStack 采用 C/S模式,server端就是salt的master,client端就是minion,minion与master之间通过ZeroMQ消息队列通信。 master监听4505和4506端口,4505对应的是ZMQ的PUB system,用来发送消息,4506对应的是REP system是来接受
42 0
【MySQL】MySQL5.6二进制安装
今天来讲【MySQL】MySQL5.6二进制安装
58 0
使用 Docker 安装并连接 MySQL
作为开发,在本机捣鼓一下 Docker 还是很有必要的,本篇文章介绍如何使用 Docker 安装 MySQL,并在终端(iTerm2)使用命令连接 MySQL。
73 0
+关注
我巴巴
编程语言 架构 相关技术专家
文章
问答
文章排行榜
最热
最新
相关电子书
更多
MySQL 5.7优化不求人
立即下载
MySQL 5.7让优化更轻松
立即下载
PostgresChina2018_张启程_为什么我们抛弃MongoDB和MySQL,选择PgSQL
立即下载