Mysql学习笔记(一)

技术的王国太过迷人,我刚从事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值。

时间: 2024-12-28 06:01:56

Mysql学习笔记(一)的相关文章

MySQL学习笔记-基础入门

MySQL学习笔记

MySql学习笔记(一)之DQL常用查询

MySql学习笔记(一)之DQL常用查询 前言:mysql是中小型的数据库软件,SQL语言分为DDL,DCL,DML,DQL四种,在这里重点讲解DQL的单表查询. 正文:在学习mysql单表查询之前,我们先做一些准备工作. 需要安装的软件如下: 1.mysql,版本可以选择5.1或者5.5,安装过程可以参考博客:http://www.cnblogs.com/ixan/p/7341637.html 2.mysql图形化管理软件:Navicate,sqlyog(二选一,推荐使用sqlyog). 本文

MySQL学习笔记-自定义函数

MySQL学习笔记-自定义函数 1.自定义函数简介 自定义函数:用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,其用法与内置函数相同 自定义函数的两个必要条件:(1)参数  (2)返回值 自定义函数: 创建自定义函数 CREATE FUNCTION function_name RETURNS {STRING|INTEGER|REAL|DECIMAL} routine_body 关于函数体: 1.函数体可以由合法的SQL语句构成: 2.函数体可以是

Mysql学习笔记(三)对表数据的增删改查。

写在前面:(一些牢骚,可以直接跳到分割线后) 太过敏感的人不会快乐,不幸的是我正是这种性格的人. 从培训机构毕业后,迫于经济方面的压力,和当时的班里的一个同学住在了一起,我们在一个公司上班.谁知道这都是不开心生活的源头,从每天早晨开始心情就很糟糕.他是个脾气很慢的人,我是个急脾气,特别是在早上上班的时候.由此种种吧,实在是不胜枚举.算了,还是不说了,太痛苦了,我不太喜欢说别人的坏话.我是学心理学的,已经用各种方法去安慰自己,但是都不太奏效. 回想以往和朋友的交往中,我虽然不算十分合群的人,但绝对

mysql 学习笔记(一)

查询:show databases;show status;show tables; desc  table-name: 更改root密码:方法一:mysqladmin -uroot -poldpassword  password newpassword方法二:mysql -uroot -puse mysqlupdate user set password=password("newpasswd") where user="root";select host,use

MySQL学习笔记-数据类型与操作数据表

MySQL学习笔记-数据类型与操作数据表 数据类型:  1.字符型  2.整型  3.浮点型  4.日期时间型 数据表操作:  1.插入记录  2.查找记录 记录操作:  1.创建数据表  2.约束的使用 1.数据类型 [1]整型: 数据类型 存储范围 字节 TINYINT 有符号型:-128~127(-2^7~2^7 -1),无符号型0~255(0~2^8 -1) 1 SMALLINT 有符号型:-2^15~2^15 -1,无符号型0~2^16 -1 2 MEDIUMINT 有符号型:-2^2

mysql学习笔记 第五天

使用分区数据表: 分区数据表和merge数据表具有相似的作用,但是分区数据表确确实实是一个数据表 ,不像merge是列出数据表的逻辑关系,并且分区数据表可以包括像myisam以外的 的数据表.创建分区数据表: create table 里给出数据列和索引,然后用partition by 定义一个用来把数据行分配 到各个分区的分区函数:[将数据表分成四个区] create table log_partition( dt datetime not null, info varchar(100) no

mysql学习笔记 第四天

mysql引擎: archive(档案)[数据插入以后不能被修改,只读] blackhole[这种写操作是删除数据,读操作是返回空白记录] CSV[在储存数据时以逗号作为数据项之间的分隔符] example[示例(存根)储存引擎] Falcon[用来进行处理事务的储存类型] federated[用来访问远程数据表的储存引擎] InnoDB[具备外键支持功能的事务处理引擎] memory[内存里的数据表] merge[用来管理多个MyISAM数据表构成的数据表集合(merg-myisam)] my

mysql 学习笔记 第二天

插入表格数据: Insert into table_name set columns_1=value1,columns_2=value2,对于没有赋值的列,将会取默认值,并且这个方法只能一次插入一个数据 利用文本方式插入数据: Load data local infile‘径’into table table_name: Select 的通用形式: Select columns from table or tables where conditions;from一般不能少的,但是当查询的时候没有

MySQL学习笔记(一)

命令行中的取消操作 如果你决定不想执行正在输入过程中的一个命令,输入\c取消它: mysql> SELECT -> USER() -> \c mysql> 这里也要注意提示符,在你输入\c以后,它切换回到mysql>,提供反馈以表明mysql准备接受一个新命令. 使用SHOW语句找出服务器上当前存在什么数据库: mysql> SHOW DATABASES; +----------+ | Database | +----------+ | mysql | | test |