PHP-mysql的数据类型

mysql中也分为三大数据类型:数值型,字符型,时间日期型

这里写图片描述


数值型

数值型分为整数型和小数型(包含小数部分的数据类型)


整型

mysql中光整数型数据类型就有五种:tinyint,smallint,mediumint,int,bigint
tinyint:迷你整型,占用1个字节保存数据,能够表示256个数值
smallint:小整型,占用2个字节保存数据,能够表示65536个数值
mediumint:中整型,占用3个字节保存数据
int:标准整型,占用4个字节保存数据,42亿多
bigint:大整型,占用8个字节保存数据

这里写图片描述

为什么要有这么多整型?
1.能够最大效率的使用磁盘空间,做到最少浪费。根据实际业务分配内存空间来进行数据保存。
2.查询的效率变高。

如何在项目中选择使用何种整型?
根据业务需求,某一类数据的边界值,看边界值落在那个整型的范围,就是用最小的那个。
在实际操作中tinyint,int使用的较多



整型表案例

这里写图片描述

默认的,整型都是有符号类型

这里写图片描述

无符号:表示数值只能是正的,不能有负数
语法:在字段类型后面使用unsigned进行标识
age tinyint unsigned;//年龄是一个迷你整型,无符号表示(0-255)

这里写图片描述

更新数据

这里写图片描述

显示宽度:占的位数,当某个数值没有达到显示宽度的时候,在数值的左边使用0来补足显示宽度(不能改变数值本身大小)

这里写图片描述

默认的,系统不会进行0填充,需要给字段显示的增加一个属性:zerofill,0填充
系统默认显示的宽度是数据类型能够显示的最大宽度。
0填充有一个特点:使用0填充的字段必须为无符号类型,不能为负数进行0填充

这里写图片描述

0填充是专门用来配合显示宽度:显示宽度只是在数据的值没有达到指定宽度的时候使用0填充,0填充或者显示宽度都不会限制原来值的大小,值的大小由数据类型决定。

这里写图片描述

什么地方会使用显示宽度?
在一些需要使用0填充地方不改变原来值的大小,却能够用宽度来固定显示数据,保证前端数据的显示不会改变原来的css结构。比如说月份,日期,时间。


小数型

带有小数部分的数据。
mysql中小数型分为两种:浮点型,定点型
  浮点型:float和double
  float:采用4个字节保存数据
  double:采用八个字节保存数据

这里写图片描述


浮点数的存储使用4个字节32位存储,第一位叫做符号位,会使用符号位后面的8位用来存储街码(底数+指数),其他的用来表示数据。
  浮点数会丢失精度
   float:最大有效位7位左右
   double:最大有效位为15位左右

浮点数的使用方式
float(M,D):M表示整个长度,D表示小数位的长度

这里写图片描述

数据处理

这里写图片描述

浮点数只适用于那些对于数值精确要求不高,但是数量特别大的数据。
凡是跟钱相关绝对不用浮点数。
1.7 ======》二进制00000001.1011001
0.7 * 2 = 1.4 1
0.4 * 2 = 0.8 0
0.8 * 2 = 1.6 1
0.6 * 2 = 1.2 1



定点型:decimal
能够自动的扩展宽度来保存数据,保证数据的精度,基于小数部分,如果超出指定长度,仍然会进行四舍五入。
语法:decimal(M,D):M表示总长度,D表示小数部分的长度

这里写图片描述

定点型与浮点型区别

这里写图片描述

定点型的数据范围

这里写图片描述


decimal(65,30)

默认的,如果不使用括号标识decimal的长度,那么默认的是decimal(10,0);
凡是涉及到钱的都会在数据库端使用decimal来进行数据的存储和运算。


字符串型

mysql有以下字符串类型:char,varchar,text,blob,enum,set
char:定长字符串,表示磁盘会分配固定长度的空间去存储数据
  如果数据不够长度,空间依然被占用
  如果数据超出长度,系统会报错
语法:char(L),L表示长度,L表示的字符长度,L的最大值是255

varchar:变长字符串,表示磁盘空间会根据实际数据的长度来自动分配存储空间,但是长度不能超过指定长度

varchar(L),存储的数据只能小于或者等于L个字符,L的理论值是65535

varchar在存储之外还有一个额外的1到2个字节来保存当前varchar的实际占用长度

char和varchar对比(utf8) :一个字符 = 3个字节

这里写图片描述

非严格模式下(集成环境中),都是对类型要求不严格,所以当数据类型不符合要求的时候,系统会进行自动转换或者截取,从而不报错。但是在严格模式中,系统不会做任何处理,只会做判断,如果失败就报错。

如何区分使用char还是varchar
1.所有字符串长度都必须在255之内
2.如果字符串长度是固定,那么使用char
 md5值,身份证,手机号等等
3.如果字符串长度不固定,那么使用varchar
 姓名,邮箱。。。



char和varchar区别
1.char的效率比varchar要高
2.varchar比char节省空间



当字符串长度超过255之后,就不会使用varchar来进行数据的保存,使用text

text:字符串文本
blob:二进制文本

在记录里面不计算长度(不占记录长度),基本可以“无限”存储数据

这里写图片描述

enum:枚举,列出一系列的元素,可以从一堆元素中任选一个作为实际的值(单选框)
语法:enum(元素1,元素2…)

这里写图片描述



枚举的意义?
1.限制用户的输入(规范数据)
2.能够节省磁盘空间

枚举使用2个字节来保存数据,能够保存65535个数据,是因为枚举实际保存的不是字符串而是字符串元素所对应的数值。

这里写图片描述



如何证明枚举实际存储的是数值呢?
使用算术运算符:mysql会在碰到算术运算符之后,自动进行数据转换,转换成数值类型。转换的标准与PHP一致。
语法:select 字段 + 0 from 表名

这里写图片描述

中文是如何输出的呢?

这里写图片描述



set:集合,在定义字段之初,为字段值做一系列的限制,实际存储值的时候,可以是集合类型中的多个元素。集合相当于多选框。
hobby set(‘游泳’,’爬山’,’打球’,’骑车’,’旅游’);
集合是使用8个字节,只能保存64个数据。集合定义的数据类型里面出现的可能的元素的最多个数为64个。

这里写图片描述

集合可以在插入数据的时候,将实际的顺序给打乱,但是最终保存的时候,系统会将顺序与定义的时候的顺序对比,变成原来的。

这里写图片描述

集合实际存储的也是数值;

这里写图片描述

原理:每一个枚举元素,都占据一个位作为自己的空间,该空间上,如果当前元素被选中,那么值为1,否则为0。最终去计算十进制结果的时候,是将所有的二进制先颠倒过来,再计算。

这里写图片描述

使用set的好处
1.节省空间
2.能够规范数据

对于枚举和集合,在进行数据插入的时候,还可以使用数值进行插入

这里写图片描述



数据库的字符串类型有很多,但是是从数据库管理员的角度出发去考虑问题。
1.考虑磁盘空间的开销
2.考虑执行效率
作为PHP程序员,基本不考虑这些,只考虑如何能够方便PHP进行操作。所以真正配合PHP使用的字符串:****char,varchar,和text


时间日期格式

这里写图片描述

datetime:表示年月日时分秒,能够表示9000年,占用8个字节
timestamp:时间戳,使用标准整型存储,表现却是年月日,时分秒
date:日期部分,可以表示1000-9999年
time:时间部分,表示的是一个时间段,从过去什么时间到以后的某个时间
year:年,使用一个字节存在,一个字节只能表示256个数值,在计算的时候加上1900再输出

timestamp时间戳并不能使用真正的时间戳

这里写图片描述

time类型可以时间时间段

这里写图片描述



注意:
1.在mysql中,任意一条记录(所有字段的集合)的长度不能超过65535个字节。
所以varchar能够存储的数据的真实长度会变化很大
GBK:varchar能够存储多少个字符?32766个字符
(65535 – 2) / 2 = 32766.5

这里写图片描述

utf8:varchar能够存储多少个字符?
(65535 – 2) / 3 = 21844.3

这里写图片描述

2.在mysql中,如果所有的字段里,没有全部不允许为null,那么需要一个字节来保存null
所有字段都不为null

这里写图片描述


留出一个字节保存null

这里写图片描述

3**.text不占存储长度空间,但是text本身需要占据10个字节来保存字段名。**

这里写图片描述

原文地址:https://blog.csdn.net/lwzhang1101

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读8.4k次,点赞8次,收藏7次。SourceCodester Online Tours & Travels Management System pay.php sql injectionLine 16 of pay.php invokes a SQL query built using unvalidated input. This call could allow an attacker to modify the statement’s meaning or to execute arbitrary SQL commands.SQL
文章浏览阅读3.4k次,点赞46次,收藏51次。本文为大家介绍在windwos系统搭建typecho博客+cpolar内网穿透工具将博客发布到公共网络环境,实现远程也可以访问和操作。_windows搭建typecho
文章浏览阅读1.1k次。- php是最优秀, 最原生的模板语言, 替代语法,让php更加的优雅的与html生活在一起 -->请放心, 最终生成的,或者说用户最终看到的,仍然是一个html文档, php代码中的内容不会被泄漏的。-- 将php与html代码混编的时候,大括号很容易造成配对错误,最好杜绝它 -->php标签内部代码由php.exe解释, php标签之外的代码原样输出,仍由web服务器解析。-- 所以php的流程控制语句, 都提供了替代语法,用冒号代替大括号 -->php echo '百变鹏仔'?_利用php将静态页面修改为动态页面
文章浏览阅读1.1k次,点赞18次,收藏15次。整理K8s网络相关笔记博文内容涉及 Linux network namespace 认知以及彼此通信Demo,实际中的应用理解不足小伙伴帮忙指正不必太纠结于当下,也不必太忧虑未来,当你经历过一些事情的时候,眼前的风景已经和从前不一样了。——村上春树。_linux network namespace 多端通信 模式认知
文章浏览阅读1.2k次,点赞22次,收藏19次。此网络模型提供了一个逻辑二层(L2)网络,该网络封装在跨 Kubernetes 集群节点的现有三层(L3)网络拓扑上。使用此模型,可以为容器提供一个隔离的 L2 网络,而无需分发路由。封装网络带来了少量的处理开销以及由于覆盖封装生成 IP header 造成的 IP 包大小增加。封装信息由 Kubernetes worker 之间的 UDP 端口分发,交换如何访问 MAC 地址的网络控制平面信息。此类网络模型中常用的封装是 VXLAN、Internet 协议安全性 (IPSec) 和 IP-in-IP。_k8s网络组件对比
文章浏览阅读1.1k次,点赞14次,收藏19次。当我们谈论网络安全时,我们正在讨论的是保护我们的在线空间,这是我们所有人的共享责任。网络安全涉及保护我们的信息,防止被未经授权的人访问、披露、破坏或修改。
文章浏览阅读1.3w次,点赞3次,收藏7次。尽管您可以通过 ping 命令解析出网站的 IP 地址,但是可能在浏览器中访问时仍然遇到问题,这可能是因为浏览器使用的 DNS 解析结果不同于 ping 命令使用的解析结果。可能是因为您的网络或设备上设置了防火墙,阻止了对特定网站的访问。有些国家或组织可能会对特定的域名进行屏蔽,从而阻止访问相关网站。如果您的网络使用代理服务器进行访问控制,可能会由于代理服务器的配置问题导致无法访问某些网站。即使您的网络和设备一切正常,目标网站本身可能也存在问题,例如服务器故障、维护或过载,导致无法访问。_能ping通打不开网页
文章浏览阅读839次,点赞22次,收藏19次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读2.1k次,点赞31次,收藏22次。基于微信小程序奶茶点餐外卖系统设计与实现(PHP后台+Mysql)可行性分析毕设源代码毕业设计,数据安全和系统稳定性以及团队能力和资源配备方面都具备较好的条件。因此,该项目的可行性较高。:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;微信小程序作为一种快捷、方便的移动应用形式,成为很多用户点餐外卖的首选。项目的界面和功能都可以定制,包安装运行!项目配有对应开发文档、开题报告、任务书、PPT、论文模版等。
文章浏览阅读1.8k次,点赞52次,收藏38次。本文主要通过对系统的前台系统和后台管理系统进行了功能性需求分析,对系统的安全性和可扩展性进行了非功能性需求分析。在详细的需求分析的基础上,根据系统的功能设计确定了数据库结构,实现完整的代码编写。Lucky+Baby母婴用品网站使用 Dreamweaver、HBuilder代码编辑器、Apache服务器等开发工具,完成了系统的主要模块的页面设计和功能实现。本文展示了首页页面的实现效果图,并通过代码和页面介绍了用户注册功能、商品搜索功能、生成订单和查看我的订单功能、在线付款功能功能的实现过程。
文章浏览阅读1.5k次,点赞45次,收藏40次。本设计主要实现集人性化、高效率、便捷等优点于一身的人事信息管理系统,完成首页、系统用户、通知公告、部门信息、员工薪资、考勤签到、员工请假、招聘信息、应聘信息等功能模块。
文章浏览阅读1k次。该错误通常出现在数据库读取结果集数据时,比如当我们写好SQL语句从数据库读取数据时,本身应该返回结果集,再给结果集中读取数据。解决思路:这种错误一般是因为echo后面输出了一个数组导致的,或者是数组作为字符串进行拼接运算时导致的。该错误直译为:警告:mysqli_fetch_assoc函数期望参数1是mysqli的结果集,但是给了一个布尔值。这种错误是PHP解析器在解析时遇到了语法错误,直译为:解析错误:语法错误,意料之外的...该错误直译为:提示:未定义的索引:username。_array to string conversion in
文章浏览阅读2.7w次。解决http请求报错context deadline exceeded (Client.Timeout exceeded while awaiting headers)_context deadline exceeded (client.timeout exceeded while awaiting headers)
文章浏览阅读1.3k次,点赞26次,收藏24次。复杂网络是一种由大量相互连接的元素(节点或顶点)组成的网络结构,这些连接通常是非常复杂和动态的。这些网络可以在各种领域中发现,包括社交网络、生物学系统、信息技术和交通系统等。_代理建模
文章浏览阅读2.6k次,点赞76次,收藏71次。epoll详解,事件模型,ET/LT模式,并通过三个示例进行代码实现。
文章浏览阅读3.3k次。罗拉ROLA-IP是一家来自纽约的代理IP提供商,由李嘉诚先生投资建设,韩国人工智能、自动驾驶、虚拟现实方面的领军企业World IT Show投资入股,由美国纽约大学IT管理教授团队研究开发,进入中国市场6年多,全世界设有多个分子公司。接下来,我们要检查代理和防火墙的设置,因为在绝大多数情况下,它们是导致这个错误的原因,尤其是当用户使用免费代理时。对网站的访问受阻实际上是一个非常常见的错误,它既可能是由于物理原因(硬件问题)造成的,也可能是由于软件错误引起的。检查代理设置,并确保其正确配置。_无法访问此网站,检查代理服务器和防火墙
文章浏览阅读1.1k次,点赞14次,收藏20次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。_php洗车服务预约管理系统php源码
文章浏览阅读1.1k次。桶排序是计数排序的升级版。它利用了函数的映射关系,高效与否的关键就在于这个映射函数的确定。同时,对于桶中元素的排序,选择何种比较排序算法对于性能的影响至关重要。
文章浏览阅读936次,点赞22次,收藏17次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读822次,点赞15次,收藏14次。在整个设计过程中,要确定可能的具体解决方案,以实现每一个小的最终目标,对于每一个小目标,我们首先必须了解一些相关的需求分析信息。除了以上作品下面是2023-2024年最新100套计算机专业原创的毕业设计源码+数据库,是近期作品,如果你的题目刚好在下面可以文末领取java源码参考。springboot基于springboot的在线考试系统。springboot基于springboot的商城购物系统。springboot基于微信小程序的智慧校园设计与实现。springboot基于用户的协同过滤算法的话题推荐。