当前位置: 首页 > news >正文

怎么做一个网站app吗金华网站建设价格

怎么做一个网站app吗,金华网站建设价格,网站域名过期怎么办,电商系统设计方案🔥个人主页:寻星探路 🎬作者简介:Java研发方向学习者 📖个人专栏:《从青铜到王者,就差这讲数据结构!!!》、 《JAVA(SE)----如此简单&a…

     🔥个人主页:寻星探路

🎬作者简介:Java研发方向学习者

📖个人专栏:《从青铜到王者,就差这讲数据结构!!!》、 《JAVA(SE)----如此简单!!!》、《数据库那些事!!!》

⭐️人生格言:没有人生来就会编程,但我生来倔强!!!



目录

一、常用数据类型分类

二、数据值类型

1、类型列表

2、数据类型取值范围

三、字符串类型

1、类型列表

2、关于排序

3、CHAR与VARCHAR的区别

4、如何选择CHAR与VARCHAR

5、VARCHAR与TEXT的区别

四、日期类型

1、类型列表

2、其他

五、总结


一、常用数据类型分类

        在面向对象软件开发的过程中,通常会先进行需求分析从而得到类和属性,类是面向对象中的概念,对应到数据库中的概念就是实体,类中的属性对应实体中的属性。实体通常以表的形式存在,每个实体对应⼀张表,表中的每条记录(数据⾏)就是实体的⼀个实例,每条记录又包含若干字段(或称为列),每个字段代表实体的⼀个属性。

        如果要定义实体的属性,就要为属性命名并指定合适的数据类型。与其他编程语言类似,SQL中规定了用于描述属性的数据类型。常用的数据类型有以下几类:

• 数据值类型

• 字符串类型

• ⼆进制类型

• ⽇期类型

二、数据值类型

1、类型列表

2、数据类型取值范围

三、字符串类型

1、类型列表

2、关于排序

(1)字符串类型的列以字符为单位,并且可以单独指定字符集和排序规则,比如字符集是utf8mb4 ,排序规则是utf8_0900_ai_ci

(2)⼆进制的列以字节为单位,可以指定_bin结尾的排序规则,比如排序规则是 utf8mb4_bin ,这时以比较和排序基于数字字符代码值

3、CHAR与VARCHAR的区别

        CHAR 固定长度的字符串, M 表示以字符为单位的列⻓度,取值范围 0 ~ 255 ,省略则长度为1 ,在存储时总是用空格向右填充到指定的长度,获取列的值时会从尾部删除空格。允许定义 CHAR(0),此时列的值只能为NULL或空字符串,主要的目的是为了旧系兼容,比如类中必须有这个属性,但不使用这个属性的值,也就是说值并没有意义,但列又不能没有。

         VA RCHAR 可变长度字符串。 M 表示以字符为单位的最大列长度,取值范围 0 ~ 65,535 (在所有列中共享),有效长度取决于实际字符数和使用的字符集,并且用额外的⼀或两个字节记录实际使用的字节数,当实际字节数不超过255个字节用⼀个字节记录长度,超过255个字节时,使用两个字节记录长度,获取列的值时不会从尾部删除空格,插入数据时会删除超出长度的空格。

mysql> CREATE TABLE vc (v VARCHAR(4), c CHAR(4));
Query OK, 0 rows affected (0.01 sec)mysql> INSERT INTO vc VALUES ('ab  ', 'ab  ');
Query OK, 1 row affected (0.00 sec)mysql> SELECT CONCAT('(', v, ')'), CONCAT('(', c, ')') FROM vc;
+---------------------+---------------------+
| CONCAT('(', v, ')') | CONCAT('(', c, ')') |
+---------------------+---------------------+
| (ab  )              | (ab)                |
+---------------------+---------------------+
1 row in set (0.06 sec)mysql> insert into vc values ('ab    ', 'ab  ');
Query OK, 1 row affected, 1 warning (0.01 sec)mysql> show warnings;
+-------+------+----------------------------------------+
| Level | Code | Message                                |
+-------+------+----------------------------------------+
| Note  | 1265 | Data truncated for column 'v' at row 1 |
+-------+------+----------------------------------------+
1 row in set (0.00 sec)

        通过下表来说明CHAR和VARCHAR存储字符串的区别,字符集以latin1为例:

4、如何选择CHAR与VARCHAR

        如果数据确定长度都⼀样,就使用定长 CHAR 类型,比如:身份证,md5,学号,邮编。

        如果数据长度有变化,就使用变长 VARCHAR ,比如:名字,地址,但要规划好长度,保证最长的字符串能存的进去。

        定长 CHAR 类型比较浪费磁盘空间,但是效率高。

        变长 VARCHAR 类型比较节省磁盘空间,但是效率低。

        定长 CHAR 类型会直接开辟好对应的存储空间。

        变长 VARCHAR 类型在不超过定义长度范围的情况下用多少开辟多少存储空间。

5、VARCHAR与TEXT的区别

        容量大小: VARCHAR 最大⽀持长度时,当超过 65535 个字节; TEXT 最大支持 65535 时自动转换为 65535 个字节,在指定TEXT MEDIUMTEXT 类型,当超过 16,777,215 时自动转换为 LONGTEXT 类型

        存储位置: VARCHAR 类型的列实际内容小于768个字节时存在当前行,大于768时存在溢出页, 当前行保存溢出页的地址; TEXT 类型的列整体保存在溢出页,当前行只保存溢出页地址

        查询性能:对于频繁查询的 VARCHAR 列可以创建索引,提升查询性能; 接创建普通索引,但可以使用列的性能高于 TEXT 类型的列无法直 FULLTEXT 索引,由于索引的支持和存储位置的不同, TEXT 类型的列

        适用场景:如果存储的数据长度较小且需要创建索引进行检索,可以选择 VARCHAR VARCHAR 类型,比如姓名,用户,邮箱等;如果存储的数据长度较大且不需要频繁以该列为条件进行检索可以选择 TEXT 类型,比如⽂章内容等。

四、日期类型

1、类型列表

2、其他

        fsp 为可选设置,用来指定小数秒精度,范围从0到6,值为0表示没有小数部分,如果省略,默认精度为0

        CURRENT_DATE 和 CURRENT_DATE() 是 CURDATE() 的同义词用于获取当前日期

        CURRENT_TIME 和 CURRENT_TIME([fsp]) 是 CURTIME() 的同义词用于获取当前时间

        CURRENT_TIMESTAMP 和 CURRENT_TIMESTAMP([fsp]) 是 NOW() 的同义词用于获取当 前日期和时间

五、总结

        关于上面所讲到的类型中,我们最需要关心的其实只有下面的这几个:

http://www.dtcms.com/a/490546.html

相关文章:

  • 芷江建设局网站石家庄网站建设公司黄页
  • Excel表----VLOOKUP函数实现两表的姓名、身份证号码、银行卡号核对
  • XMLHttpRequest.responseType:前端获取后端数据的一把“格式钥匙”
  • office便捷办公06:根据相似度去掉excel中的重复行
  • Vue+mockjs+Axios 案例实践
  • http的发展历程
  • Python中使用HTTP 206状态码实现大文件下载的完整指南
  • AngularJS下 $http 上传文件
  • 如何弄死一个网站锡林郭勒盟建设工程造价管理网站
  • 【Node.js】为什么擅长处理 I/O 密集型应用?
  • 基于SpringBoot的无人机飞行管理系统
  • STM32的HardFault错误处理技巧
  • Tekever-固定翼无人机系统:模块化垂直起降、远程海上无人机、战术 ISR 无人机
  • Kafka Queue: 如何严格控制消息数量
  • 大兴建设网站wordpress 托管主机
  • 国外html响应式网站网站开发高级证
  • 苍穹外卖--04--Redis 缓存菜品信息、购物车
  • 大淘客网站如何做seowordpress o2o主题
  • 机器学习催化剂设计专题学习
  • (六)机器学习之图卷积网络
  • 告别刀耕火种:用 Makefile 自动化 C 语言项目编译
  • 【安卓开发】【Android】做一个简单的钢琴模拟器
  • C#控制反转
  • 【Java 开发日记】什么是线程池?它的工作原理?
  • 黄页网站数据来源wordpress 最新漏洞
  • 如何评价3D高斯泼溅(3DGS)技术为数字孪生与实时渲染带来的突破性进展?
  • 技术解析:如何将NX(UG)模型高效转换为3DXML格式
  • 阿里云智能建站网络类黄页
  • SAP MIR7 模拟过账没有这个按钮
  • Redis 分布式锁实战:解决马拉松报名并发冲突与 Lua 原子性优化