mysql 刘道成视频教程 第4-8课 --- 数据类型
数据类型大纲图:
注:在mysql中,输入时,除了数值型,不要加单引号,其他的都要加上单引号,养成一种好习惯。
一、数值型:
- 整数型:
1)从数学上来讨论tinyint
1、 占据空间
2、存储范围
2)tinyint 微小的列类型,1字节,
如果表示正数,表示范围0 - > 2^8-1 : 0 -> 255;
如果表示负数,表示范围 -128 -> 127 (只有后7位表示绝对值,最高位表示的是符号) (补码)
- 小数型:
- float(M,D):M代表总位数,D代表小数位,(6,2)为例;-9999.99 -> +9999.99
- 浮点,定点型所占字节是固定的,有些是4个字节,有些是8个字节。
- 浮点型的M, D 影响存储范围
- float(4,2) : -99.99 -> +99.99
- float(4,2) unsigned : 0 -> 99.99
二、字符型:
1、char与varchar的区别
1)宽度
- char(M),M代表宽度,0 <= M <= 255之间
- varchar(M),M代表宽度,0 <= M <= 65535(以ascii字符为例,utf8 22000左右)
2)实占空间
- char:M
- varchar:i字符+(1-2)字节
类型 |
宽度 |
可存字符 |
实存字符(i<=M) |
实占空间 |
利用率 |
Char |
M |
M |
i |
M |
i/M <= 100% |
Varchar |
M |
M |
i |
i字符+(1-2)字节 |
i/(i+1-2) < 100% |
3)对末尾的处理
char型 如果实际存储内容不足M个,则后面加空格补齐;取出来的时候,再把后面的空格去掉,所以,如果内容最后有空格,将会被清除。
4)速度
char型处理速度比varchar快。
2、char与varchar选择原则:
1)空间利用率
- 四字成语表,char(4)
- 个人简介,微博140字,varchar(140)
2)速度
- 用户名:char
3、Text 文本类型:
- 可以存比较大的文本段,搜索速度稍慢,因此不是特别大的内容,建议用char,varchar来代替。
- Text 不用加默认值(加了也没用)
三、时间/日期型:
1、Year类型:1个字节 表示 1901-2155,[0000,表示错误时选择]
- 如果输入2位,’00-69’ 表示: 2000-2069
- 如果输入2位,’70-99’ 表示: 1970-1999
- 如果记的麻烦,输入的时候,输4位。
2、Date类型:典型格式 1992-08-12
- 日期类型:’1000-01-01’ à ‘9999-12-31’
3、time类型:典型格式 hh:mm:ss
- 时间类型:’-838:59:59’ -> ‘+838:59:59’
4、Datetime 类型 典型格式:’1989-05-06 14:32:08’
- 日期时间类型 范围:1000-01-01 –> 9999-12-31 23:59:59
注意:
在开发中,很少用日期时间类型来表示一个需要精确到秒的列。
原因:虽然日期时间类型能精确到秒,而且方便查看;
真正精确到秒的,使用时间戳来表示。
- 时间戳:用来int来存储
- 是1970-01-01 00:00:00 到当前的秒数。
- 一般存注册时间,商品发布时间等,并不是用datetime存储,而是用时间戳
- 因为datetime虽然直观,但计算不便。
而用int型 存储时间戳,方便计算,对于显示来说,也可以方便的格式化。
mysql 刘道成视频教程 第4-8课 --- 数据类型的更多相关文章
- mysql 刘道成视频教程1、2课----------大致结构
第1课 第2课 一.整体结构 1.mysql -h localhost -u root -p *** 如果-h不写,则默认连接localhost. 2.连接服务器成功,-------> 显示数据 ...
- mysql 刘道成视频教程 第3课
第3课: 1.mysql中条件使用关键字where: 2.查 select name,content from msg ; select name,content 控制列 where id>2 ...
- KALI LINUX WEB 渗透测试视频教程—第十九课-METASPLOIT基础
原文链接:Kali Linux Web渗透测试视频教程—第十九课-metasploit基础 文/玄魂 目录 Kali Linux Web 渗透测试视频教程—第十九课-metasploit基础..... ...
- Kali Linux Web 渗透测试视频教程— 第十六课-拒绝服务攻击
Kali Linux Web 渗透测试视频教程— 第十六课-拒绝服务攻击 文/玄魂 目录 Kali Linux Web 渗透测试视频教程— 第十六课-拒绝服务攻击................... ...
- Kali Linux Web 渗透测试视频教程—第十四课-arp欺骗、嗅探、dns欺骗、session劫持
Kali Linux Web 渗透测试视频教程—第十四课-arp欺骗.嗅探.dns欺骗.session劫持 文/玄魂 目录 Kali Linux Web 渗透测试—第十四课-arp欺骗.嗅探.dns欺 ...
- 备忘:MySQL中修改表中某列的数据类型、删除外键约束
-- MySQL中修改表中某列的数据类型 ALTER TABLE [COLUMN] 表名 MODIFY 列名 列定义; -- 删除外键约束 SHOW CREATE TABLE 表名; -- 复制CON ...
- MySQL 性能优化--优化数据库结构之优化数据类型
MySQL性能优化--优化数据库结构之优化数据类型 By:授客 QQ:1033553122 优化数字数据(Numeric Data) l 对于唯一ID或其它可用字符串或数字表示的值,选择 ...
- JFinal视频教程-JFnal学院分享课
最近JFinal学院出了JFinal视频教程分享课,请笑纳~ 课程列表: 1.[JFinal版]微信小程序富文本渲染解决方案-html2wxml4J分享课 这个课程主要讲的是使用基于JFinal开发的 ...
- 【C#入门经典视频教程】-第001课-C#入门-认识C#
C#入门-认识C# C ---> C++ --> C# (C++++) j++ j++ 有一门可能比这个C#更流行的语言 java 使用的教程:c#入门经典第五版 操作系统:windows ...
随机推荐
- 有7g和2g的砝码各一个,怎样称可以3次把140g东西分为50g和90g???????
第一次:等分 50和90为 70 70 2. 7g 和2g ,取出一个70中的9g , 61 70 3.利用 9g和2g砝码,取出61中的11克,前面的9 和 11 都放进70
- JavaScript高级程序设计28.pdf
classList属性 在操作类名时需要通过className属性添加.删除和替换类名 <div class="bd user disabled">...</di ...
- 3 视频里weekend05、06、07的可靠性 + HA原理、分析、机制 + weekend01、02、03、04、05、06、07的分布式集群搭建
现在,我们来验证分析下,zookeeper集群的可靠性 现在有weekend05.06.07 将其一个关掉, 分析,这3个zookeeper集群里,杀死了weekend06,还存活weekend05. ...
- 黑马程序员_<<GUI(图形用户界面)--------1>>
--------------------ASP.Net+Android+IOS开发..Net培训.期待与您交流! -------------------- 1. GUI图形用户界面 1.简述 Gra ...
- Test Bench基础知识笔记
学的内容多了,好多指令和用法都容易遗忘和混淆,出现这种情况就需要勤记笔记,忘记了多翻阅几次,基本上就能完全记住了. [`timescale 1ns/1ps]前一个1ns表示时延时间,后一个1ps表示时 ...
- jQuery--对话框插件--dialog
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 传输层:TCP UDP SCTP
总图 虽然协议族被称为“TCP/IP”,但除了TCP和IP这两个主要协议外,还有许多其他成员.图2-1展示了这些协议的概况. 图2-1中同时展示了IPV4和IPV6.从右向左看该图,最右边的5个网络应 ...
- 在Nginx中搭建Nagios监控平台
本文只做Nginx下Nagiox安装的说明,其它关于Nagios监控的详细配置请参考我的另一篇文章[Ubuntu 10.04下构建Nagios监控平台] Nagios依赖PHP环境和perl环境.由于 ...
- Chrome浏览器离线下载地址(Stable/Beta/Dev)
最新稳定版:https://www.google.com/intl/zh-CN/chrome/browser/?standalone=1 最新测试版:https://www.google.com/in ...
- UTF-8 BOM对PHP的影响
今天在用notepad++写代码时 载入一个frameset框架模版后 在页面上一直不显示该页面,查看源码后都正常.然后索性把里面东西全删掉 随便写了几个测试文字可以正常显示. 折腾了好长时间,最后偶 ...