字段的约束

  • (一)常用约束介绍
  • (二)创建带约束字段的语法格式
  • (三)主键与自增长
  • (四)非空
  • (五)唯一
  • (六)默认值


(一)常用约束介绍

  • 主键(primary key):值不能重复,auto_increment 代表值自动增长;
  • 非空(not null):此字段不允许填写空值;
  • 唯一(unique):此字段不允许重复;
  • 默认值(default):当不填写此值时会使用默认值,如果填写时以填写为准。

(二)创建带约束字段的语法格式

create table 表名(字段名 数据类型 约束,字段名 数据类型 约束...
);

(三)主键与自增长

  • 带有 primary key(主键)的字段,值不能重复;
  • auto_increment 为自增长;
create table 表名(字段名 数据类型 primary key auto_increment,字段名 数据类型 约束...
);

例1:创建表 d,字段要求如下:
id:数据类型为 int unsigned(无符号整数),primary key(主键),auto_increment(自增长);
name:数据类型为varchar(字符串),长度为10;
age:数据类型为 int(整数)。

create table d(id int unsigned primary key,name varchar(10),age int
);

(这个要先把第七行“运行已选择的”,再把第八行“运行已选择的”)
在这里插入图片描述
主键:不能重复。这里是 id 不能重复。
如果插入一条相同 id 的记录(id 为1),会是什么结果呢?
在这里插入图片描述
报错啦。

我们来查询一下表 d :
在这里插入图片描述
name还是’貂蝉’,name值为’妲己’的记录并没有插入。

▲我们来看“auto_increment”的作用:
首先,我们drop删除一下表:

drop table d;

然后,新建表d:

CREATE TABLE d(id INT UNSIGNED PRIMARY key aotu_increment,name VARCHAR(10),age int
);

我们只插入了指定字段,没有插入 id,它会自动把 id 写成 1。

在这里插入图片描述
插入第二条没有指定 id 的记录的时候,id自动写成2。
在这里插入图片描述

如果插入一条指定 id 的记录,查询结果的 id 是指定的 id 值。
在这里插入图片描述
▲ 如果插入数据时,插入所有字段,但又没写自增长字段的值,insert 语句会出错。

insert into d values ('甄姬',20);

解决方案:
使用占位符,通常使用0 或者null 来占位。

insert into d (id,name,age) values (0,'甄姬',20);
insert into d (id,name,age) values (null,'甄姬',20);

▲ truncate 和 delete:
delete:删除后再次新建,id 会接着原来的最后一条记录的 id 值继续自增,不会回到1。
truncate:删除后再次新建,id 从1开始。


(四)非空

带有 not null (非空)的字段,值不能为空。

create table 表名(字段名 数据类型 not null,...
);

例1:创建表 e,字段要求如下:
id:数据类型为 int unsigned(无符号整数);
name:数据类型为 varchar,长度为10,not null;
age:数据类型为 int。

create table e(id int unsigned,name varchar(10) not null,age int
);

▲ 非空字段表,insert 插入数据一定要指定字段值,不然会插入失败。


(五)唯一

此字段的值不允许重复。

create table 表名(字段名 数据类型 unique,...
);

例1:
创建表 f,字段要求如下:
id:数据类型为 int;
name:数据类型为 varchar,长度为10,unique;
age:数据类型为 int。

create table f(id int,name varchar(10) unique,age int
);

▲ 唯一字段的表,insert 语句插入数据。
例2:表 f 插入一条记录

insert into f values (1,'瑶',18);

例3:如果插入的记录中 name 值重复,会插入失败。

insert into f values (2,'瑶',20);

(六)默认值

当不填写此值时会使用默认值,如果填写时以填写为准。

create table 表名(字段名 数据类型 default,...
);

例1:
创建表 g,字段要求如下:
id:数据类型为 int;
name:数据类型为 varchar,长度为10;
age:数据类型为 int,default,30。

create table g(id int,name varchar(10),age int default 30
);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/98847.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/98847.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/98847.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据可视化-112】使用PyEcharts绘制TreeMap(矩形树图)完全指南及电商销售数据TreeMap绘制实战

🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

Linux下编译MMCV

介绍 MMCV 有两个主要版本,mmcv 和 mmcv-lite。 mmcv 是全面版本,包含所有的特性以及丰富的开箱即用的 CUDA 算子,但构建时间较长;mmcvlite 是精简版,不包含 CUDA 算子,但拥有其他所有功能,适…

Spring Boot 分布式事务常见问题:Seata、XA 与本地消息表对比

一、前言在单体应用中,事务一般由关系型数据库本身来保证,通过 ACID 特性实现数据一致性。但随着微服务架构的普及,应用被拆分为多个独立服务,数据可能分散在不同数据库、不同存储引擎中,传统的单机事务无法再覆盖。这…

Transporter App 使用全流程详解:iOS 应用 ipa 上传工具、 uni-app 应用发布指南

在 iOS 应用开发与发布过程中,Transporter App 是苹果官方提供的一款上传工具,专门用于将 ipa 文件 或 应用资源 上传到 App Store Connect。 与 Xcode 上传 相比,Transporter 更加稳定,尤其适合大文件上传,因此在 iOS…

计算机毕业设计 基于Hadoop的B站数据分析可视化系统的设计与实现 Python 大数据毕业设计 Hadoop毕业设计选题【附源码+文档报告+安装调试】

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python、大数据、人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇&…

使用自定义LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成

使用自定义LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成 说明: 首次发表日期:2024-07-12Vanna Github地址: https://github.com/vanna-ai/vannaVanna官方文档: https://vanna.ai/ 部署Vanna时我们可以选择使…

Linux多线程概念

背景知识内存管理OS进行内存管理不是以字节为单位的,而是以内存块为单位的,默认大小为4kb;系统和磁盘文件进行IO交互的单位是4kb(8个扇区);OS对内存管理实质上是对页框进行管理。页框(Page Fram…

【Problem】动态规划之跳跃游戏系列

一、跳跃游戏 55. 跳跃游戏 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/jump-game/description/?envTypeproblem-list-v2&envIddynamic-programming class Solution { public:bool canJump(vector<int>& nums) {// 状态定义&#x…

射频EVM

EVM&#xff08;Error Vector Magnitude&#xff0c;误差矢量幅度&#xff09;是衡量无线通信系统中调制质量的重要指标&#xff0c;尤其用于评估信号的调制误差和系统性能。它通常用来表示传输信号与理想信号之间的偏差&#xff0c;特别是在数字通信中。EVM的基本概念&#xf…

Java 更改 Word 文档中文本颜色

在日常的自动化文档处理中&#xff0c;我们经常会遇到需要对 Word 文档内容进行编程修改的需求&#xff0c;其中一项常见且重要的操作就是更改文本的颜色。无论是为了突出重点、统一品牌风格&#xff0c;还是实现动态内容展示&#xff0c;精准地修改文本颜色都是一个核心痛点。…

STM32—SPI协议

文章目录一、SPI 协议简介二、硬件电路2.1.SPI的连接2.2.数据的移位2.3.时序基本单元2.3.1.起始条件和终止条件2.3.2.模式 02.3.3.模式 12.3.4.模式 22.3.5.模式 32.4.时序三、软件实现四、W25Q644.1.简介4.2.硬件电路4.3.框图4.4.操作注意事项五、实验一、SPI 协议简介 SPI&a…

Qt中的QWebEngineView

第1章 本地目录结构1.1 自己写的两个网页(html)mermaid.html &#xff08;自己写的网页界面&#xff09;WebTest.html (自己写的网页界面)qwebchannel.js (Qt下载安装之后&#xff0c;会在安装目录下有这个文件&#xff0c;需要将安装目录下的改文件拷贝…

Flutter 应用国际化 (i18n) 与本地化 (l10n) 完整指南

Flutter 国际化 (i18n) 完全指南&#xff1a;从入门到精通 在现代移动应用开发中&#xff0c;支持多语言是触达全球用户的基本要求。Flutter 提供了强大且灵活的国际化 (i18n) 和本地化 (l10n) 支持。本文将带你从零开始&#xff0c;一步步深入掌握在 Flutter 中实现国际化的几…

计算机视觉与深度学习 | 计算机视觉中线特征提取与匹配算法综述

文章目录 一、线特征提取算法原理 1.1 Hough变换及其优化 1.2 LSD算法 1.3 EDLines算法 二、核心数学公式 2.1 直线表示与误差计算 2.2 LSD算法关键公式 三、线特征匹配算法 3.1 LBD描述符 3.2 匹配策略 四、代码实现 4.1 LSD线段检测(Python) 4.2 LBD特征匹配(C++) 五、算…

Transformer 模型:Attention is All You Need 的真正含义

2017 年&#xff0c;Google Brain 发布了一篇具有里程碑意义的论文——《Attention Is All You Need》&#xff0c;这篇论文不仅首次提出了 Transformer 模型&#xff0c;更重要的是&#xff0c;它宣称“注意机制&#xff08;Attention Mechanism&#xff09;就足以构建强大的模…

数据库约束表的设计

数据库约束概念&#xff1a;数据库约束是关系型数据库的一个重要功能&#xff0c;主要是保证数据的完整性&#xff0c;也可理解为数据的正确性&#xff08;数据本身是否正确&#xff0c;关联关系是否正确&#xff09;&#xff08;一般是用在指定列上&#xff09;常见的约束类型…

【案例分享】TeeChart 助力 Softdrill 提升油气钻井数据可视化能力

在钻井与地质工程领域&#xff0c;数据可视化是核心环节。图表不仅需要精确与高效&#xff0c;还需符合行业习惯并支持交互与定制。Softdrill 自 2012 年起在核心产品中集成了TeeChart 图表库&#xff0c;将复杂的井下数据转化为直观的工程图表&#xff0c;极大提升了钻井工程师…

【Flink】Flink Runtime 架构设计

Flink Runtime 架构设计 整体架构 ┌─────────────────────────────────────────────────────────────────┐ │ Flink Runtime │ ├─────────…

Git 命令教程

Git介绍 分布式版本控制系统。 Git命令 初始化/全局配置git init初始化一个Git仓库&#xff08;会创建一个.git的目录&#xff09;git config --global user.name “name”设置提交时的用户名git config user.name查看设置的用户名git config --global user.email “youemail.c…

git config --global user.name指令报错时的解决方案

问题分析 %HOMEDRIVE%%HOMEPATH%/.gitconfig 是Windows环境变量的表示方式&#xff1a; %HOMEDRIVE% 通常是 C:%HOMEPATH% 通常是 \Users\你的用户名完整路径应该是&#xff1a;C:\Users\你的用户名\.gitconfig 但这里环境变量没有被正确解析&#xff0c;显示的是字面意思。 …