引言

  这次Qi号分享MySQL字段属性简介。下面资料是Qi号搜集大量资料与个人理解的整理。

  MySQL提供了一组可以赋给表中各个列的数据类型,每个类型都强制数据满足为该数据类型预先确定的一组规则,例如大小、类型及格式。

  这里先总结数据类型。MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。

  参考资料:

数据类型介绍

  1. 日期和时间数据类型

MySQL数据类型   含义
date 3字节,日期,格式:2014-09-18
time 3字节,时间,格式:08:42:30
datetime 8字节,日期时间,格式:2014-09-18 08:42:30
timestamp 4字节,自动存储记录修改的时间
year 1字节,年份
 
 
 
 
 
 
 
 
 
 
 
 
 
  2. 数值数据类型
 
MySQL数据类型 含义(有符号)
tinyint 1字节,范围(-128~127)
smallint  2字节,范围(-32768~32767)
mediumint  3字节,范围(-8388608~8388607)
int 4字节,范围(-2147483648~2147483647)
bigint 8字节,范围(+-9.22*10的18次方)

  上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了。

  比如:tinyint unsigned的取值范围为0~255。

  3. 浮点型

MySQL数据类型 含义
float(m, d) 4字节,单精度浮点型,m总个数,d小数位
double(m, d) 8字节,双精度浮点型,m总个数,d小数位
decimal(m, d) decimal是存储为字符串的浮点数

  

  单精度与双精度的区别:双精度比单精度表示的位数大 精确的位数多

  4. 字符串数据类型

MySQL数据类型 含义
char(n) 固定长度,最多255个字符
varchar(n) 可变长度,最多65535个字符
tinytext 可变长度,最多255个字符
text 可变长度,最多65535个字符
mediumtext 可变长度,最多2的24次方-1个字符
longtext 可变长度,最多2的32次方-1个字符
常见字段类型事项

  1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。

  2.同时char和varchar最大的区别就在于char不管实际value长度多少,都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1{varchar在结尾会有结束符}),并且实际空间+1<=n。

  3.超过char和varchar的n设置后,字符串会被截断。

  4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。

  5.char在存储的时候会截断尾部的空格,varchar和text不会。

  6.varchar会使用1-3个字节来存储长度,text不会。

最后Qi号给大家分享一道曾微软、GOOGLE、百度、腾讯等公司都用过的面试题:
 
题目:过桥算法

  

  在漆黑的夜里,四位旅行者来到了一座狭窄而且没有护栏的桥边。如果不借助手电筒的话,大家是无论如何也不敢过桥去的。不幸的是,四个人一共只带了一只手电筒,而桥窄得只够让两个人同时通过。如果各自单独过桥的话,四人所需要的时间分别是1,2,5,8分钟;而如果两人同时过桥,所需要的时间就是走得比较慢的那个人单独行动时所需的时间。问题是,你如何设计一个方案,让用的时间最少。

最新文章

  1. Mac下环境变量配置
  2. iOS -- 上传多张图片 后台(PHP)代码和上传一张的一样
  3. 低字节序和高字节序相互转换(Little Endian/Big Endian)
  4. Jobs定时器 - Quartz
  5. Qt sqlite
  6. UVA11090 Going in Cycle!! (二分+SPFA推断有无负权)
  7. java实现线程的3中方式
  8. 腾讯qq等级计算公式面试题
  9. Java学习笔记17(面向对象十:综合案例)
  10. Cocos2D iOS之旅:如何写一个敲地鼠游戏(八):为动画建立属性列表
  11. BZOJ_3438_小M的作物_最小割
  12. SQL数据库一些系统语法含义
  13. Android 图片高级绘图效果---高斯模糊
  14. Ionic 图片延时加载
  15. 最近无意中看到一个讲解spring mvc的系列,从源码的角度讲解,特记录下来,供以后反复学习
  16. 这份书单,给那些想学Hadoop大数据、人工智能的人
  17. mnist手写数字识别(SVM)
  18. GNU m4 教程[转]
  19. 异步和等待(async和await)
  20. Advanced Data Structures in competitive programming

热门文章

  1. node搭环境(四)--webpack启服务运行VUE模块文件(手写简单脚手架)
  2. MVC在页面View上获取当前控制器名称、Action名称以及路由参数
  3. 初次搭建spring boot 项目(实验楼-学习笔记)
  4. css画扇形按钮
  5. Chrome拷贝插件的对比 zeroclipboard和clipboard插件
  6. Android setUserVisibleHint-- fragment真正的onResume和onPause方法
  7. Android内存监测工具使用
  8. Arm启动流程解析
  9. android selector中使用shape
  10. Struts1.x 基本原理及注册模块的实现