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

鞍山网站建设工作室怎么在百度发帖

鞍山网站建设工作室,怎么在百度发帖,什么是ui设计图,数据分析网站文章目录 为什么要有约束一. 空属性二. 默认值三. 列描述四. zerofill结束语 为什么要有约束 数据库是用来存放数据的,所以其需要保证数据的完整性和可靠性 数据类型也算是一种约束,比如,整型的数据无法插入字符型。 通过约束,让…

文章目录

  • 为什么要有约束
  • 一. 空属性
  • 二. 默认值
  • 三. 列描述
  • 四. zerofill
  • 结束语

为什么要有约束

数据库是用来存放数据的,所以其需要保证数据的完整性和可靠性
数据类型也算是一种约束,比如,整型的数据无法插入字符型。
通过约束,让插入数据库的数据都是符合预期的,倒逼程序员插入正确的数据,而通过约束,在MySQL视角中,只要是插入成功的数据,都是符合预期的

一. 空属性

NULL(空)
NOT NULL(不为空)
' '(空串)
空串和空是不一样的,比如没有建行银行卡是空,空串是有建行银行卡但是没有钱
NULL不参与任何计算

mysql> select 1+NULL;
+--------+
| 1+NULL |
+--------+
|   NULL |
+--------+

我们在建表时,属性如果没有说明not null,默认可以为NULL

mysql> create table student(-> id varchar(6),-> name varchar(3)-> );mysql> desc student;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| id    | varchar(6) | YES  |     | NULL    |       |
| name  | varchar(3) | YES  |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
//插入数据
mysql> insert into student values (1,NULL);
Query OK, 1 row affected (0.01 sec)mysql> select * from student;
+------+------+
| id   | name |
+------+------+
| 1    | NULL |
+------+------+

NULL一列为YES,允许为空。
但是这并不合理,既然要插入数据,学生的姓名和学号都不应该为空。

mysql> create table student(-> id varchar(6) not null,-> name varchar(3) not null-> );mysql> insert into student values (1,NULL);
ERROR 1048 (23000): Column 'name' cannot be null
mysql> insert into student values (1,'张三');
Query OK, 1 row affected (0.00 sec)mysql> select * from student;
+----+--------+
| id | name   |
+----+--------+
| 1  | 张三   |
+----+--------+mysql> show create table student \G;
*************************** 1. row ***************************Table: student
Create Table: CREATE TABLE `student` (`id` varchar(6) NOT NULL,`name` varchar(3) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8

建表属性也会显示NOT NULL

二. 默认值

Default 默认值
默认值的使用是在该属性没有显示插入数据时使用
在创建表时,如果没有指定默认值,那么默认值为NULL

mysql> create table t1(-> id int-> );mysql> desc t1;                 //默认为空
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
1 row in set (0.00 sec)mysql> show create table t1 \G;
*************************** 1. row ***************************Table: t1
Create Table: CREATE TABLE `t1` (`id` int(11) DEFAULT NULL//默认为空
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

在建表时,指定默认值,那么在插入数据时,若没显示插入该属性数据,则使用默认值

mysql> create table person(->name varchar(4) not null,->age tinyint unsigned default 18
);mysql> insert into person (name) values ('张三');
Query OK, 1 row affected (0.00 sec)mysql> select * from person;
+--------+------+
| name   | age  |
+--------+------+
| 张三   |   18 |
+--------+------+

PS:如果设定属性为NOT NULL,则没有默认值
因为在建表属性中没有default null

mysql> create table t1(-> id int not null-> );mysql> show create table t1 \G;
*************************** 1. row ***************************Table: t1
Create Table: CREATE TABLE `t1` (`id` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8

三. 列描述

列描述:comment 建表时使用,相当于注释,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。

mysql> create table person(-> name varchar(4) not null comment '姓名',-> age tinyint unsigned comment '年龄',-> gender varchar(1) comment '性别'-> );mysql> show create table person \G;
*************************** 1. row ***************************Table: person
Create Table: CREATE TABLE `person` (`name` varchar(4) NOT NULL COMMENT '姓名',`age` tinyint(3) unsigned DEFAULT NULL COMMENT '年龄',`gender` varchar(1) DEFAULT NULL COMMENT '性别'
) ENGINE=InnoDB DEFAULT CHARSET=utf8

四. zerofill

创建int类型属性时,显示的是int(10),这个10是什么意思呢?
其实是最大能显示的位数个数,使用zerofill验证

mysql> create table t1( ->id1 int,->id2 int zerofill->);mysql> desc t1;
+-------+---------------------------+------+-----+---------+-------+
| Field | Type                      | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+---------+-------+
| id1   | int(11)                   | YES  |     | NULL    |       |
| id2   | int(10) unsigned zerofill | YES  |     | NULL    |       |
+-------+---------------------------+------+-----+---------+-------+mysql> insert into t1 values (200,200);mysql> select * from t1;
+------+------------+
| id1  | id2        |
+------+------------+
|  200 | 0000000200 |
+------+------------+

使用zerofill会将没有显示的位数用0填充
因为int为4个字节,有符号的int最大表示21亿,10位数足够表示,而无符号的使用11位表示足够

结束语

感谢你的阅读

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

http://www.rdtb.cn/news/14960.html

相关文章:

  • 重庆大渡口营销型网站建设公司推荐国外搜索引擎网址
  • 免费网站源码下载器怎么注册自己的网站
  • 给网站做图如何建立网站 个人
  • 太原网站域名搭建短视频营销优势
  • 北京seo网站推广seo专业知识培训
  • 用啥网站做首页网站关键词收录查询
  • b2c网站建设旅游aso优化排名推广
  • 海曙网站建设网站日照网站优化公司
  • 汕头快速建站模板seo推广外包
  • 舆情app免费优化推广seo
  • 昆山网站推广郑州seo
  • 宝安营销型网站设计最新推广方法
  • 视差 长沙做网站360外链
  • 电脑做科目一网站十大收益最好的自媒体平台
  • 校园网站建设资金来源有近期新闻热点
  • 做类似58同城大型网站网络营销工具平台
  • 网站建设深圳哪家好sem推广竞价托管
  • 义乌城市建设规划网站如何做好一个营销方案
  • 公安用什么系统做网站十大免费推广平台
  • 房产网站怎么做400电话淮北网络推广
  • logo是黑色 怎么调网站的色调青岛网站关键词排名优化
  • 微网站 pc网站同步百度指数的网址
  • 毕业设计做啥网站好详细的营销推广方案
  • wordpress文章添加按钮沈阳seo建站
  • 杭州公司网站建设电话数据统计网站
  • 国外优秀企业网站运营和营销的区别和联系
  • eclipse做的网站刷关键词排名软件
  • 苹果dj站这类网站做需要多少钱seo还有哪些方面的优化
  • 1000套网站源码湖北网站建设制作
  • 创客贴做网站吗衡阳网站优化公司