mysql学习笔记

InnoDB引擎与MyISAM引擎

mysql是关系型数据库。其中的存储引擎可以show engines来查看。我的版本是5.6.26的,查看版本用select version() 来查看。5.6.26的mysql有9种存储引擎。其中最常见最老生常谈的也就是MyISAM 与InnoDB。如果业务上是非事物(transcation)的那么这两种存储引擎都差不多,在性能上没什么差别。如果业务中需要大多数的select 查询,那么可以用MyISAM存储引擎。如果是需要事物,则需要用回InnoDB存储。

MySQL的备份

备份的时候为了避免数据不一致的情况,再数据库备份期间,不允许对数据库进行写操作。

可以用 flush tables with read lock;

现将内存中的表数据扫描恢复到表里面。然后锁定表。同事给予读权限。也就是说在数据库备份的时候,还是有读权限的。

等数据库的备份操作完成之后,然后对数据库解锁。tables unlock;

MySQL数据类型

书本上这个数据类型结构图画的挺好的,到网上搜了一下,都花的不好看。于是还是自己画一个吧,用不了多长时间。

麻蛋,我的画图工具坏了,我就总结个知识,何苦呢。

下面还是文字吧,文字来的快,省力。

小数类型分为精确小数类型和浮点小数类型。

小数类型包括decimal精确类型。

浮点小数,包括单精度和双精度。(这个我也不知道是啥意思,有兴趣的百度之吧,比较常用的是decimal)。'

decimal(length, precision) 。lengh表示这个数总共有多长,precision表示小数点后有多长。

MySQL的字符串类型

MySQL主要支持六种字符串类型,char , varchar, tinyintm, text, mediumtext, longtext.

在字符串的类型上面我以前认识不清。犯过许多错误。看过书,然后实验后,就明白了许多。

以下内容直接引用《MySQL 核心技术与最佳实践》第三章节。

char(n) 是定长字符串类型, 表示占用 n个字符(注意不是字节) 的 存储空间,n的最大值为255.例如,对于中文简体字符集gbk编码来说,char(255)表示可以存储255个汉字,而每个汉字占用两个字节的存储空 间。对于一个utf8字符集的字符串而言,char(255)表示可以存储255个汉字,而每个汉字占用3个字节的存储空间。

varchar(n) 为变长字符串类型,这就意味着此类字符串占用的存储空间就是字符串自身占用的存储空间,与n无关。这与char(n)不同,这与char(n)不同。例如 对于中文简体字符集gbk的字符串而言,varchar(255)表示可以存储255个汉字。而每个汉字占用两个字节的存储空间。假若这个字符串没有那么 多的汉字,例如仅仅包括一个“中”字,那么varchar(255)仅仅占用一个字符(2个字节)的存储空间,如果不考虑其他开销。而char(255) 必须占用255个字符长度的存储空间,哪怕里面只存储一个汉字。

各种字符类型占用的存储空间:

MySQL的日期类型

MySQL主要支持5中日期类型。date, time,year,datetime,timestamp。

date类型。格式支持年月日。YYYY—MM—DD;

time类型。时分秒。 HH:ii:ss。

datetime 是date与time的结合体。也就是年月日。时分秒了。

timestamp 和datetime差不多。

可是学习上不能讲究差不多。我们还是来看下timestamp与datetime的区别吧。

表示的取值范围不同,datetime的取值范围远远大于timestamp的取值范围。timestamp到2037年就玩完了。

如果timestamp不赋值,那么该字段值的值实际上是mysql服务器当前的日期和时间。

对同一个timestamp类型的日期或者时间。不同的失去显示的结果不同。使用MySQL命令show varialbes like "time_zone" 可以会显示如下的信息。

这个SYSTEM就表示用的是系统的时间。

当对包含timestamp数据的记录进行修改是,timestamp数据将自动更新为mysql服务器当前的日期和时间。

MySQL二进制类型

我应该不会在MySQL数据库存二进制的数据类型,至少目前不会涉及。只了解一下mysql可以存二进制数据,我想就够了。以后有需要再回来研究。

一点感悟:

(1)在符合应用要求(取值范围 精度)的情况下,尽量使用短的的数据类型。

(2) 数据类型越简单越好。

(3)尽量采用精确的小数类型。

(4)尽量用内置的日期和时间数据类型,而不是用字符串来存储日期和时间。

(5) 尽量避免null字段,建议将字段指定为not null 约束。这是由于,在mysql中含有空值的列很难进行查询优化,null值会是索引的统计信息以及比较优化运算变得更加复杂。推荐使用0,一个特殊的值或者一个空字符串代替null值。

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2015-10-18

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏java思维导图

Java 单例以及单例所引发的思考

1 前言 前几天无意中看到一篇文章,讲到了老生常谈的单例,抱着复习一下的心态点了进去,还是那些熟悉的内容,可是却发现自己思考的角度变了,以前更多的是去记忆,只停...

2947
来自专栏Greenplum

Greenplum 对JSON的支持

源文章:http://www.postgresqltutorial.com/postgresql-json/

841
来自专栏chenssy

【死磕Sharding-jdbc】---结果合并

接下来以执行 SELECT o.*FROM t_order o whereo.user_id=10order byo.order_id desc limit 2...

1223
来自专栏沃趣科技

MySQL排序内部原理探秘

一、我们要解决什么问题 二、排序,排序,排序 三、索引优化排序 四、排序模式 4.1实际trace结果 4.2排序模式概览 4.2.1回表排序模式 4.2.2不...

5036
来自专栏逸鹏说道

如何让所有实体类用相同名称的主键(很有力的问题,比如所有表实体主键都用ID)

这个问题比较有力量,哈哈! 例如:有两个表userbases和products 两个表的主键分别为UserID和ProductID,那么,我想问有没有一种方法把...

3155
来自专栏技术博客

Entity Framework DataAnnotations

DataAnnotation 特性由.NET 3.5中引进,给.NET中的类提供了一种添加验证的方式。但是在EF中它又可以对映射关系进行控制,相比较Fluent...

973
来自专栏xingoo, 一个梦想做发明家的程序员

AngularJS API之toJson 对象转为JSON

toJson()能把对象序列化为json 方法讲解 这个方法最多支持2个参数: angular.toJson(obj, pretty); obj 是想要转换的...

2525
来自专栏Golang语言社区

go语言的sql包原理与用法分析

go的sql包是在pkg/database中,里面的两个包sql和sql/driver可以一起看。建议看这个两个包之前可以先看看sql文件夹下的doc.txt。...

3034
来自专栏数据结构与算法

SPOJ1043 GSS1(线段树)

注意查询的时候不能按照以前的方式写,因为不知道变量的下界,最稳妥的办法就是判三种情况

1041
来自专栏java学习

Java每日一练(2017/8/2)

本期题目: (单选题)1、在 java 中,一个类可同时定义为许多同名的方法,这些方法的形式参数个数,类型或顺序各不相同,传回的值可能个不相同,这种面向对象的...

2907

扫码关注云+社区

领取腾讯云代金券