mysql怎么获取数据表字段enum类型的默认值

mysql怎么获取数据表字段enum类型的默认值,第1张

mysql怎么获取数据表字段enum类型的默认值

本节主要内容:

MySQL数据类型之枚举类型ENUM

MySQL数据库提供针对字符串存储的一种特殊数据类型:枚举类型ENUM,这种数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧,前面介绍了首先介绍了四种数据类型的特性总结,其后又分别介绍了布尔类型BOOL或称布尔类型BOOLEAN,以及后续会再单独介绍集合类型SET。

本文详细介绍集合类型enum测试过程与总结,加深对mysql数据库集合类型enum的理解记忆。

n 枚举类型ENUM

a).数据库表mysqlops_enum结构

执行数据库表mysqlops_enum创建的SQL语句:

复制代码代码示例:

root@localhost : test 11:22:29>CREATE TABLE Mysqlops_enum(ID INT NOT NULL AUTO_INCREMENT,

-> Job_typeENUM('DBA','SA','Coding Engineer','JavaScript','NA','QA','','other') NOT NULL,

-> Work_City ENUM('shanghai','beijing','hangzhou','shenzhen','guangzhou','other') NOT NULL DEFAULT 'shanghai',

-> PRIMARY KEY(ID)

-> )ENGINE=InnoDB CHARACTER SET 'utf8' COLLATE 'utf8_general_ci'

Query OK, 0 rows affected (0.00 sec)

执行查询数据库表mysqlops_enum结构的SQL语句:

复制代码代码示例:

root@localhost : test 11:23:31>SHOW CREATE TABLE Mysqlops_enum\G

*************************** 1. row ***************************

Table: Mysqlops_enum

Create Table: CREATE TABLE `Mysqlops_enum` (

`ID` int(11) NOT NULL AUTO_INCREMENT,

`Job_type` enum('DBA','SA','Coding Engineer','JavaScript','NA','QA','','other') NOT NULL,

`Work_City` enum('shanghai','beijing','hangzhou','shenzhen','guangzhou','other') NOT NULL DEFAULT 'shanghai',

PRIMARY KEY (`ID`)

) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8

1 row in set (0.00 sec)

小结:

为方便测试枚举类型,如何处理字段定义的默认值、是否允许为NULL和空值的情况,我们定义了2个枚举类型的字段名,经过对比创建与查询数据库中表的结构信息,没有发现MySQL数据库默认修改任何信息。

b). 写入不同类型的测试数据

写入一条符合枚举类型定义的记录值:

复制代码代码示例:

root@localhost : test 11:22:35>INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(1,'QA','shanghai')

Query OK, 1 row affected (0.00 sec)

测试第二个枚举类型字Work_City是否允许为空记录值:

复制代码代码示例:

root@localhost : test 11:22:42>INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(2,'NA','')

Query OK, 1 row affected, 1 warning (0.00 sec)

root@localhost : test 11:22:48>SHOW WARNINGS

+---------+------+------------------------------------------------+

| Level | Code | Message |

+---------+------+------------------------------------------------+

| Warning | 1265 | Data truncated for column 'Work_City' at row 1 |

+---------+------+------------------------------------------------+

1 row in set (0.00 sec)

测试第二个枚举类型字段Work_City是否允许存储NULL值:

复制代码代码示例:

root@localhost : test 11:22:53>INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(3,'Other',NULL)

ERROR 1048 (23000): Column 'Work_City' cannot be null

测试第一个枚举类型字段Job_type是否可以存储空白值:

复制代码代码示例:

root@localhost : test 11:22:59>INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(4,'','hangzhou')

Query OK, 1 row affected (0.00 sec)

测试第二个枚举类型字段Job_City如何处理没有在定义中描述的值域第一个枚举类型字段Work_Type的默认值没指定情况下,会默认填写那个值:

复制代码代码示例:

root@localhost : test 11:23:06>INSERT INTO Mysqlops_enum(ID,Work_City) VALUES(5,'ningbo')

Query OK, 1 row affected, 1 warning (0.00 sec)

root@localhost : test 11:23:13>SHOW WARNINGS

+---------+------+------------------------------------------------+

| Level | Code | Message |

+---------+------+------------------------------------------------+

| Warning | 1265 | Data truncated for column 'Work_City' at row 1 |

+---------+------+------------------------------------------------+

1 row in set (0.00 sec)

测试第二个枚举类型字段未插入数据的情况下,是否能使用上字段定义中指定的默认值:

复制代码代码示例:

root@localhost : test 11:23:17>INSERT INTO Mysqlops_enum(ID,Job_type) VALUES(6,'DBA')

Query OK, 1 row affected (0.00 sec)

如何获取mysql中枚举类型的值

mysql_query("SET NAMES 'utf-8'")

修改成

mysql_query("SET NAMES 'UTF8'")

mysql取值可为星期一到星期天七天中的某一天的枚举类型很准确。根据查询相关资料信息显示,mysql取值可为星期一到星期天七天中的某一天的枚举类型是weekday枚举,weekday枚举类型常用于各项专业,所以mysql取值可为星期一到星期天七天中的某一天的枚举类型很准确。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8595354.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-18
下一篇 2023-04-18

发表评论

登录后才能评论

评论列表(0条)

保存