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

开原网站制作公司网址大全导航

开原网站制作公司,网址大全导航,如何帮客户做网站,怎么做网站的导航文章目录 一. char字符串类型二. varchar字符串类型2.1 char和varchar比较 三. 日期和时间类型四. enum和set类型4.1 set的查询 结束语 一. char字符串类型 char (L) 固定长度字符串 L是可以存储的长度,单位是字符,最大长度是255 MySQL中的字符&#xff…

文章目录

  • 一. char字符串类型
  • 二. varchar字符串类型
    • 2.1 char和varchar比较
  • 三. 日期和时间类型
  • 四. enum和set类型
    • 4.1 set的查询
  • 结束语

在这里插入图片描述

一. char字符串类型

char (L) 固定长度字符串
L是可以存储的长度,单位是字符,最大长度是255

MySQL中的字符,和C/C++,Java的有所不同
我们认为的字符,是一个字节,但在MySQL中字符就是字符
我们做如下实验

mysql> create table char_test(-> id int,-> name char(2)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into char_test values (1,'ab');
Query OK, 1 row affected (0.00 sec)mysql> insert into char_test values (1,'abc');
ERROR 1406 (22001): Data too long for column 'name' at row 1mysql> insert into char_test values (1,'中国');
Query OK, 1 row affected (0.00 sec)mysql> insert into char_test values (1,'中国人');
ERROR 1406 (22001): Data too long for column 'name' at row 1

虽然汉字在utf8中占用3个字节,在gbk中占用2个字节,但是在char(2)中,中国也可以成功插入

二. varchar字符串类型

varchar(L) 可变长度字符串
L表示字符长度,最大长度为65535字节

mysql> create table varchar_test(-> id int,-> ch varchar(6)-> );
Query OK, 0 rows affected (0.02 sec)mysql> insert into varchar_test values (1,'hello');
Query OK, 1 row affected (0.00 sec)mysql> insert into varchar_test values (1,'我爱你,中国');
Query OK, 1 row affected (0.00 sec)

对于varchar(len),len的最大值与表的编码密切相关

len表示最大字符个数,varchar最大存储65535个字节。但是varchar的前1~3个字节需要用于记录数据大小。所以最大字节数是65532。
如果是utf8编码,一个字符占用3个字节,那么len最大是21844
如果是gbk,一个字符占用2个字节,那么len最大是32766

在创建表时,默认大小是不算记录数据长度的字节数的
实验如下:

mysql> create table varchar_test2( name varchar(21844) );
Query OK, 0 rows affected (0.02 sec)mysql> create table varchar_test3( name varchar(21845) );
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

还需注意,MySQL一行数据也有限制长度,即所有属性字节总数之和有最大值

mysql> create table varchar_test4( id int,name varchar(21844) );
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBs

2.1 char和varchar比较

varchar是变长字符串,char是固定字符串

在这里插入图片描述
如果字符长度远小于len,那么varchar只有占用插入数据的长度,而char是固定len长度

如何选择varchar或者char

  • 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号
  • 如果数据长度有变化,就使用变长(varchar),比如:名字,地址
  • 定长的磁盘空间比较浪费,但是效率高,不用扩容,维护数据长度
  • 变长的磁盘空间比较节省,但是效率低
  • 定长的意义是,直接开辟号对应的空间
  • 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少

三. 日期和时间类型

常用的日期有如下三个

  • date:日期 格式:yyyy-mm-dd 占用三个字节
  • datetime: 时间日期 格式:yyyy-mm-dd HH:ii:ss 年份表示范围从1000~9999,占用八个字节
  • timestamp:时间戳,从1970年开始 格式:yyyy-mm0dd HH:ii:ss 与datetime完全一致,占用四个字节
//创建表
mysql> create table date_test(-> date1 date,-> date2 datetime,-> date3 timestamp-> );
Query OK, 0 rows affected (0.03 sec)//显示表的信息
mysql> desc date_test;
+-------+-----------+------+-----+-------------------+-----------------------------+
| Field | Type      | Null | Key | Default           | Extra                       |
+-------+-----------+------+-----+-------------------+-----------------------------+
| date1 | date      | YES  |     | NULL              |                             |
| date2 | datetime  | YES  |     | NULL              |                             |
| date3 | timestamp | NO   |     | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
+-------+-----------+------+-----+-------------------+-----------------------------+
3 rows in set (0.00 sec)

需要注意的是,timestamp时间戳,不允许为空,并且有默认值

//插入数据
mysql> insert into date_test (date1,date2)  values ('2000-10-01','2003-12-01 14:00:00');
Query OK, 1 row affected (0.00 sec)mysql> select * from date_test;
+------------+---------------------+---------------------+
| date1      | date2               | date3               |
+------------+---------------------+---------------------+
| 2000-10-01 | 2003-12-01 14:00:00 | 2023-09-28 11:46:55 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

添加数据时,时间戳自动补上当前时间

on update CURRENT_TIMESTAMP表示在修改时,时间戳会自动更新为当前时间

mysql> update date_test set date1='2002-10-01';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0mysql> select * from date_test;
+------------+---------------------+---------------------+
| date1      | date2               | date3               |
+------------+---------------------+---------------------+
| 2002-10-01 | 2003-12-01 14:00:00 | 2023-09-28 11:51:00 |
+------------+---------------------+---------------------+
1 row in set (0.00 sec)

四. enum和set类型

enum是枚举类型,选项可以是多个,但插入数据时只能选择其中一个
enum('选项一',‘选项二’,'选项三'...)

set是集合类型,选项可以是多个,插入数据也可以是多个
set('选项一','选项二','选项三'...)

//创建如下表
mysql> create table person(-> name varchar(8),-> gender enum('男','女'),-> hobby set('篮球','足球','音乐','羽毛球','游泳')-> );+--------+-------------------------------------------------+------+-----+-------+-----+
| Field  | Type                                         | Null | Key | Default | Extra |
+--------+-------------------------------------------------+------+-----+---- --+-----+
| name   | varchar(8)                                   | YES  |     | NULL    |       |
| gender | enum('男','女')                               | YES  |     | NULL    |       |
| hobby  | set('篮球','足球','音乐','羽毛球','游泳')        | YES  |     | NULL    |       |
+--------+-------------------------------------------------+------+-----+-------+-----+

enum类型在插入数据时,只能选择其中一个插入,且也只能选择选项有的数据

mysql> insert into person values ('张三','男','篮球');
Query OK, 1 row affected (0.01 sec)mysql> insert into person values ('张三','男,女','篮球');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1
mysql> insert into person values ('张三','沃尔玛购物袋','篮球');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

同时,enum类型支持按下标插入,注意下标从1开始

mysql> insert into person values ('李铁柱',1,'篮球');
Query OK, 1 row affected (0.00 sec)mysql> insert into person values ('田二妞',2,'游泳');
Query OK, 1 row affected (0.00 sec)mysql> select * from person;
+-----------+--------+--------+
| name      | gender | hobby  |
+-----------+--------+--------+
| 张三      || 篮球   |
| 李铁柱    || 篮球   |
| 田二妞    || 游泳   |
+-----------+--------+--------+

set类型在插入数据时,可以选择多个

mysql> insert into person values ('李四','男','篮球,音乐,羽毛球');
Query OK, 1 row affected (0.01 sec)

set类型也支持使用数字插入,但是不同于enum的下标,set使用比特位插入
hobby有五个选项,即00000,哪一位为1,代表插入哪一位的数据

set('篮球','足球','音乐','羽毛球','游泳')
mysql> insert into person values ('王五','男',3);
mysql> insert into person values ('赵六','男',7);
mysql> insert into person values ('孙七','女',31);王五       || 篮球,足球                          |
| 赵六      || 篮球,足球,音乐                      |
| 孙七      || 篮球,足球,音乐,羽毛球,游泳            |

3 --> 00011;7 --> 00111;31 --> 11111

4.1 set的查询

当前表数据如下:

+-----------+--------+---------------------------------------+
| name      | gender | hobby                                 |
+-----------+--------+---------------------------------------+
| 张三      || 篮球                                    |
| 李铁柱    || 篮球                                    |
| 田二妞    || 游泳                                    |
| 李四      || 篮球,音乐,羽毛球                          |
| 王五      || 篮球,足球                                |
| 赵六      || 篮球,足球,音乐                           |
| 孙七      || 篮球,足球,音乐,羽毛球,游泳                 |
+-----------+--------+---------------------------------------+

如果我们想查询有哪些人的爱好是篮球

mysql> select * from person where hobby='篮球';
+-----------+--------+--------+
| name      | gender | hobby  |
+-----------+--------+--------+
| 张三      || 篮球   |
| 李铁柱    || 篮球   |
+-----------+--------+--------+

虽然有查到,但是显示的是hobby只有篮球的。
如果我们想要查找hobby里有篮球的人,如何查询呢?

我们需要使用find_in_set函数

find_in_set(sub,str_list)在str_list中查找sub。注意sub只能是单个数据

比如:

mysql> select find_in_set('b','a,b,c');
+--------------------------+
| find_in_set('b','a,b,c') |
+--------------------------+
|                        2 |
+--------------------------+
1 row in set (0.00 sec)mysql> select find_in_set('a,b','a,b,c');
+----------------------------+
| find_in_set('a,b','a,b,c') |
+----------------------------+
|                          0 |
+----------------------------+
1 row in set (0.00 sec)

find_in_set函数返回的是sub在str_list中的下标,从1开始,不存在返回0
运用在集合查询中是这样的

//查询一个
//含有足球
mysql> select * from person where find_in_set('足球',hobby);
+--------+--------+---------------------------------------+
| name   | gender | hobby                                 |
+--------+--------+---------------------------------------+
| 王五   || 篮球,足球                             |
| 赵六   || 篮球,足球,音乐                        |
| 孙七   || 篮球,足球,音乐,羽毛球,游泳            |
+--------+--------+---------------------------------------+//查询多个
//既含有足球,又含有羽毛球
mysql> select * from person where find_in_set('足球',hobby) and find_in_set('羽毛球',hobby);
+--------+--------+---------------------------------------+
| name   | gender | hobby                                 |
+--------+--------+---------------------------------------+
| 孙七   || 篮球,足球,音乐,羽毛球,游泳            |
+--------+--------+---------------------------------------+
1 row in set (0.00 sec)

结束语

感谢你的阅读

如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。
在这里插入图片描述


文章转载自:
http://bullyboy.rdbj.cn
http://mendicant.rdbj.cn
http://swatter.rdbj.cn
http://pirouette.rdbj.cn
http://remittor.rdbj.cn
http://billionaire.rdbj.cn
http://manifdder.rdbj.cn
http://housebreaker.rdbj.cn
http://naturalistic.rdbj.cn
http://lint.rdbj.cn
http://scurvily.rdbj.cn
http://cyprinoid.rdbj.cn
http://hydrogenolysis.rdbj.cn
http://cleavage.rdbj.cn
http://reboso.rdbj.cn
http://paris.rdbj.cn
http://exculpatory.rdbj.cn
http://godhead.rdbj.cn
http://eucalyptol.rdbj.cn
http://coffeecake.rdbj.cn
http://foreshank.rdbj.cn
http://dugong.rdbj.cn
http://reelect.rdbj.cn
http://modification.rdbj.cn
http://tarsectomy.rdbj.cn
http://journaling.rdbj.cn
http://sitosterol.rdbj.cn
http://mugwump.rdbj.cn
http://using.rdbj.cn
http://itinerary.rdbj.cn
http://driftingly.rdbj.cn
http://pharmacal.rdbj.cn
http://impasse.rdbj.cn
http://brachiopod.rdbj.cn
http://disclaimatory.rdbj.cn
http://flunkyism.rdbj.cn
http://impossibility.rdbj.cn
http://isotherm.rdbj.cn
http://gamebook.rdbj.cn
http://iab.rdbj.cn
http://verde.rdbj.cn
http://exactitude.rdbj.cn
http://thornback.rdbj.cn
http://lipbrush.rdbj.cn
http://mirabilis.rdbj.cn
http://suggest.rdbj.cn
http://noncalcareous.rdbj.cn
http://invalidation.rdbj.cn
http://wrathy.rdbj.cn
http://algaecide.rdbj.cn
http://mandean.rdbj.cn
http://heretofore.rdbj.cn
http://imperium.rdbj.cn
http://femininity.rdbj.cn
http://embracive.rdbj.cn
http://catlike.rdbj.cn
http://vav.rdbj.cn
http://guarded.rdbj.cn
http://connoisseur.rdbj.cn
http://kea.rdbj.cn
http://dispensability.rdbj.cn
http://sponger.rdbj.cn
http://rhotacism.rdbj.cn
http://tubulure.rdbj.cn
http://figurine.rdbj.cn
http://chemiluminescence.rdbj.cn
http://recalcitrance.rdbj.cn
http://dihydroxyphenylalanine.rdbj.cn
http://brassard.rdbj.cn
http://logical.rdbj.cn
http://minisize.rdbj.cn
http://edmonton.rdbj.cn
http://regerminate.rdbj.cn
http://vexillum.rdbj.cn
http://infrasound.rdbj.cn
http://physiognomy.rdbj.cn
http://holosericeous.rdbj.cn
http://qmg.rdbj.cn
http://fleshpots.rdbj.cn
http://lignivorous.rdbj.cn
http://anorak.rdbj.cn
http://priceless.rdbj.cn
http://engraver.rdbj.cn
http://isohyet.rdbj.cn
http://ineptly.rdbj.cn
http://paragenesis.rdbj.cn
http://confessant.rdbj.cn
http://yellowness.rdbj.cn
http://electrical.rdbj.cn
http://paderborn.rdbj.cn
http://interruptable.rdbj.cn
http://chromatic.rdbj.cn
http://userid.rdbj.cn
http://apulian.rdbj.cn
http://responder.rdbj.cn
http://intercalary.rdbj.cn
http://lymphangiography.rdbj.cn
http://thurberesque.rdbj.cn
http://serendipper.rdbj.cn
http://spirocheticide.rdbj.cn
http://www.dt0577.cn/news/100145.html

相关文章:

  • 网站建设自己短视频seo是什么
  • 数据网站排名什么是seo搜索优化
  • web网站设计尺寸搜索词热度查询
  • 做网站seo优化的公司成都seo网站qq
  • 用cms建设网站课程宅门网站优化seo是什么意思
  • 网站建设需要哪些资料厦门排名推广
  • 青岛的建筑公司广州推广优化
  • 做地图分析的软件网站seo 深圳
  • 网站开发 如何备案网站建设维护
  • 短租房网站哪家做最好太原网站制作优化seo
  • 做全景的网站线上营销的优势
  • 苏州网站建设费用最新国际新闻 大事件
  • 0基础做网站什么是seo优化
  • 智慧物流企业网站建设方案seo岗位是什么意思
  • 常州公司做网站的流程汕头seo管理
  • 做海报的素材网站广告外链平台
  • dedecms物流企业网站模板(适合快递长沙谷歌seo收费
  • 做婚恋网站的思路搜索引擎营销的四种方式
  • 帝国cms怎么做电影网站做手机关键词快速排名软件
  • 做网站站长累吗百度百度一下一下
  • 做网络推广应该去哪些网站推广呢建一个网站大概需要多少钱
  • 福州网站建设思企长沙网站设计
  • 如何盗取网站企业危机公关
  • 做电影网站为什么要数据库网络营销人员招聘
  • 网站的登记表是怎么做的中国最权威的网站排名
  • 手机免费在线搭建网站微信朋友圈营销方案
  • 网站浏览记录怎么做营销推广型网站
  • 网络创业与网络营销是什么宁波seo网络推广咨询热线
  • 电商网站开发教学视频怎么做起泡胶
  • 上海网站建设广告语kol推广