技术的王国太过迷人,我刚从事IT就被各种技术所引诱迷惑,什么都想学。我还算言而有信的那一类人,还好有一丁点毅力,于是各种东西都沾染了一点。但是这种遍地开花的情况实在和我的智商不匹配。我没有那么多的精力去学那么多的东西。慢慢的要学会暂时放弃一些技术,先深化学习自己工作中要用到的东西。比如mysql等。对于自己特别喜欢的东西,比如linux,因为太过高深和复杂。我又不想放弃,那么就每天分给linux一个小时的时间,熟悉下命令,徐徐渐进。等我赖以生存的各种技能比较完善后,我想可以抽出大量的时间去研究linux了。

我是一边看书一边敲栗子的,书名是《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值。

本人博客所有文章,均为原创。部分文章中或引用相关资料,但均已著明来源出处。可随意转载、分享,但需加本文链接,以及版权说明。

以上就是Mysql学习笔记(一)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关标签:Mysql

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

mysql php教程笔记_Mysql学习笔记(一)相关推荐

  1. mysql 加号的作用_MySQL学习笔记(一)

    MySQL学习笔记(一) 作者:易成勇 案例来源:AI技术前线 MySQL常用命令 1.查看当前所有数据库 show databases; 2.打开指定的库 use 库名 3.查看当前库的所有表 sh ...

  2. mysql没法修改数据_MySQL学习笔记之数据的增、删、改实现方法

    本文实例讲述了MySQL学习笔记之数据的增.删.改实现方法.分享给大家供大家参考,具体如下: 一.增加数据 插入代码格式: insert into 表明 [列名-] values (值-) creat ...

  3. mysql原生建立索引_MySQL学习笔记之索引

    索引是存储引擎用于快速找到记录的一种数据结构. 索引对于良好的性能非常关键.尤其是当表中的数据量越来越大时,索引对性能的影响愈发重要.在数据量较小且负载较低时,不恰当的索引对性能的影响可能还不明显,但 ...

  4. mysql 查找相似数据_MySQL学习笔记之索引

    索引是存储引擎用于快速找到记录的一种数据结构. 索引对于良好的性能非常关键.尤其是当表中的数据量越来越大时,索引对性能的影响愈发重要.在数据量较小且负载较低时,不恰当的索引对性能的影响可能还不明显,但 ...

  5. mysql 去重后拼接_mysql学习笔记(三)—— 查询select

    本节主要介绍查询语句(select),包括基础查询.条件查询.模糊查询,以及一些常用函数包括:去重函数distinct.字符拼接函数concat.null判断函数ifnull. 内容都是自己学习后从S ...

  6. mysql传小马_Mysql 学习笔记

    1.关系型数据库 关系:由行和列组成的二维表 表:至少要有列,可以没有行. 列:是实体的属性. 数据模型:层次模型.网状模型.关系模型.非关系模型. DBMS:DataBase Mangenent S ...

  7. mysql innodb 索引结构_Mysql 学习笔记:InnoDB 索引结构浅析

    索引是检索图书资料的一种工具,把书刊中的内容或项目分类摘录,注明页数,按一定次序排列. 针对不同的数据存储结构有不同的数据查找方式. 1. 数据结构 1.1 B树 B树又名平衡多路查找树,主要用于文件 ...

  8. linux将mysql的错误连接数_Mysql学习笔记(十二) 并发参数调节

    mysql是多线程结构,包括后台线程和客户服务线程,多线程可以有效利用服务器资源,提高数据库的并发性能.在mysql的并发能力上,主要有有下列参数界定.分别为max_connections,back_ ...

  9. mysql悲观锁 更新_MySQL学习笔记(四)悲观锁 for update

    恼骚 最近在搞并发的问题,订单的异步通知和主动查询会存在并发的问题,用到了Mysql数据库的 for update 锁 在TP5直接通过lock(true),用于数据库的锁机制 Db::name('p ...

  10. mysql行级安全_MySQL学习笔记(五):MySQL表级锁和行级锁

    一:概述 相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制.比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking ...

最新文章

  1. 如何从0到1打造一款AI产品?
  2. 构建eureka高可用服务
  3. HAPPY2020暑假训练前复习
  4. Android 入门(四) | Intent 实现 Activity 切换
  5. Android免费短信验证
  6. 剑指Offer:二进制中1的个数
  7. 禁止用户打开控制台调试代码
  8. The file contains a character that cannot be represented in the current code pag
  9. Spring入门第十七课
  10. Linux开发_多线程编程
  11. 联想微型计算机ai0,联想baby AI
  12. 2-AltiumDesigner原理图设计
  13. 融资融券开户超干货学习!
  14. 拔掉MacBookPro,用8GB树莓派4工作一天,体验原来是这样的
  15. flowchart图
  16. USB CCID理解
  17. 蓝桥杯 单片机 决赛 第7届 电压、频率采集设备
  18. C语言学习总结(三)-----函数指针
  19. word 以嵌入式插入图片显示不全,被文字掩盖在下方
  20. 大型网站之存储瓶颈(数据库的垂直拆分)

热门文章

  1. cocos2d-x android游戏使用自己的字体
  2. Android静默安装
  3. 对象的比较与排序(二):实现IComparable和IComparer接口 和 Comparer类(转)
  4. [Html]Jekyll 代码高亮的几种选择
  5. 分享Android开发的一些工具
  6. BZOJ2832[AHOI2012] 信号塔
  7. Oracle函数登录验证,Oracle密码验证函数与Create Profile
  8. python提示line3_Python小技巧:Python3中利用tab键进行代码提示-阿里云开发者社区...
  9. java线程执行顺序执行_Java多线程系列四——控制线程执行顺序
  10. 唤醒屏幕_屏幕保护程序被困在Mac上?如何解决它