数据库中的约束纯干货——主键约束

目录

(一)特点:

(二)添加主键约束

2.1格式:

2.2举例:

2.3建立表级约束:

2.4建立表后增加主键约束

(三)复合主键

3.1格式:

3.2举例:


作用:用来唯一标识表中的一行记录

关键字:PRIMARY KEY

(一)特点:

1.主键约束相当于唯一约束+非空约束的组合。

2.主键约束列不允许重复,也不允许出现空值。

3.一个表最多只能有一个主键约束,可以在列级创建,也可以在表级别上创建

4.主键约束对应表中的一列或多列(复合主键)

5.当创建主键约束时,系统默认会在所在的列或列组合上建立对应的主键索引(主键查询的效率更高)

6.删除主键约束了,主键约束对应的索引就自动删除

7.不要修改主键字段的值,因为主键是数据记录的唯一标识,修改了就有可能破坏数据完整性


(二)添加主键约束

2.1格式:

CREATE TABLE 表明(
字段名 数据类型 PRIMARY KEY ,
字段名 数据类型
);
CREATE TABLE 表明(
字段名 数据类型,
字段名 数据类型,
CONSTRAINT 约束名 PRIMARY KEY(字段名)
);

2.2举例:

CREATE TABLE students(
id INT PRIMARY KEY ,
name VARCHAR(10)
);

添加值:

INSERT INTO students
values(1,'zha'),
(2,'zha'),#添加成功
(1,'zhang ')#添加失败,因为id重复
(3,null)#添加成功
(null,'asd')#添加失败,id不能为空

如果一个表建立两个主键约束:

CREATE TABLE students(
id INT PRIMARY KEY ,
name VARCHAR(10) PRIMARY KEY
);

报错:Multiple多重的

2.3建立表级约束:

CREATE TABLE students(
id INT  ,
name VARCHAR(10),
CONSTRAINT stu_id_test PRIMARY KEY(id) 
);

2.4建立表后增加主键约束

ALTER TABLE 表名称 ADD PRIMARY KEY(id);#字段列表可以是一个字段也可以是多个字段,如果是多个字段的话,是复合主键

(三)复合主键

3.1格式:
 

CREATE TABLE 表名(
字段名 数据类型,
字段名 数据类型,
PRIMARY KEY (字段名1,字段名2)
);

3.2举例:

CREATE TABLE students(
id INT  ,
name VARCHAR(10) ,
PRIMARY KEY(id,name)
);

添加值:

INSERT INTO students
values(1,'zha'),
(1,'sa'),#添加成功
(2,'sa ')#添加成功
(1,zha)#添加失败与第一条重复

(四)删除主键

ALTER TABLE 表名称
DROP PRIMARY KEY;

注:删除时,不需要指定主键名,因为一个表只有一个主键,删除主键约束后,非空还存在

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

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

相关文章

每日一题 --- 快乐数[力扣][Go]

快乐数 题目:202. 快乐数 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为: 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到…

Pocket 2荧光拍摄的几个有趣玩法

荧光是现象,当某种常温物质经某种波长的入射光(通常是或)照射,吸收光能后进入,并且立即退激发并发出出射光(通常波长比入射光的波长,原先看不见的短波长紫外线,变成在可见光波段的可…

JAVA的NIO和BIO底层原理分析

文章目录 一、操作系统底层IO原理1. 简介2. 操作系统进行IO的流程 二、BIO底层原理1. 什么是Socket2. JDK原生编程的BIO 三、Java原生编程的NIO1. 简介2. NIO和BIO的主要区别3. Reactor模式4. NIO的三大核心组件5. NIO核心源码分析 一、操作系统底层IO原理 1. 简介 IO&#x…

font-spider压缩文字

FZLanTingHei-DB-GBK是我引入的字体包名字 1.安装依赖 建议全局安装但是要注意npm配置 我配成了_globel 真是沙雕 npm install font-spider -g2. 在static文件夹新增一个文件夹font-spider 同时在font-spider文件夹里面新增index.css和index.html index.css font-face {f…

产品推荐 | 基于华为海思ARM+Xilinx FPGA双核的8路SDI高清视频图像处理平台

一、板卡概述 PCIE703 是我司自主研制的一款基于 PCIE 总线架构的高性能综 合视频图像处理平台,该平台采用 Xilinx 的高性能 Kintex UltraScale 系列 FPGA 加上华为海思的高性能视频处理器来实现。 华为海思的 HI3531DV200 是一款集成了 ARM A53 四核处理 器性能强…

Java设计模式—备忘录模式(快照模式)

定义 备忘录模式提供了一种状态恢复的实现机制,使得用户可以方便地回到一个特定的历史步骤,当新的状态无效或者存在问题时,可以使用暂时存储起来的备忘录将状态复原,很多软件都提供了撤销(Undo)操作&#…

什么是DevOps?如何使用DevOps?

无论您是在维持公司基础设施的正常运行,还是在为客户的IT问题管理提供支持,抑或是在构建、测试或修复软件,还是在保护同事免受安全威胁,您都可能接触过 DevOps。 毕竟,这个术语已经出现了 15 年,其采用率也…

基于单片机的二维码LCD显示控制设计

**单片机设计介绍,基于单片机的二维码LCD显示控制设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机的二维码LCD显示控制设计是一个集硬件、软件与通信于一体的综合性项目。此设计的主要目标是实现单片机…

Linux_应用篇(02) 文件 I/O 基础

本章给大家介绍 Linux 应用编程中最基础的知识,即文件 I/O(Input、 Outout) , 文件 I/O 指的是对文件的输入/输出操作,说白了就是对文件的读写操作; Linux 下一切皆文件,文件作为 Linux 系统设计…

Win11 安装docker 及 WSL2 并更新安装位置及迁移

1 下载并安装运行 Docker Desktop 1.1 下载 Docker Desktop 点击链接下载 Docker Desktop:https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe 下载后得到: 1.2 通过命令行安装 Docker Desktop 在 Docker Desktop Install…

HEVC的Profile和Level介绍

文章目录 HEVCProfile(配置):Level(级别):划分标准 HEVC HEVC(High Efficiency Video Coding),也称为H.265,是一种视频压缩标准,旨在提供比先前的…

云数据仓库Snowflake论文完整版解读

本文是对于Snowflake论文的一个完整版解读,对于从事大数据数据仓库开发,数据湖开发的读者来说,这是一篇必须要详细了解和阅读的内容,通过全文你会发现整个数据湖设计的起初原因以及从各个维度(架构设计、存算分离、弹性…

简单的LAMP部署

目录 一、准备环境 二、安装apache组件 三、安装mysql组件 四、安装php组件 五、浏览器访问 一、准备环境 iptables -F #清空防火墙规则 systemctl stop firewalld #关闭防火墙 setenforce 0 …

vue3封装Element表格自适应

表格高度自适应 分页跟随表格之后 1. 满屏时出现滚动条 2. 不满屏时不显示滚动条 坑 表格设置maxHeight后不出现滚动条 解决方案 表格外层元素设置max-height el-table–fit 设置高度100% .table-box {max-height: calc(100% - 120px); } .el-table--fit {height: 100%; }示例代…

MYSQL8.0安装、配置、启动、登入与卸载详细步骤总结

文章目录 一.下载安装包1.方式一.官网下载方式二.网盘下载 二.解压安装三.配置1.添加环境变量 三.验证安装与配置成功四.初始化MYSQL五.注册MySQL服务六.启动与停止MYSQL服务七.修改账户默认密码八.登入MySQL九.卸载MySQL补充:彻底粉碎删除Mysql 一.下载安装包 1.方…

GLTFExporter是一个用于将3D场景导出为glTF格式的JavaScript库。

demo案例 GLTFExporter是一个用于将3D场景导出为glTF格式的JavaScript库。下面我将逐个讲解其入参、出参、属性、方法以及API使用方式。 入参(Input Parameters): GLTFExporter的主要入参是要导出的场景对象和一些导出选项。具体来说: s…

PowerBI加权计算权重

1.打开主页,点击快速度量值 2.计算里面 选择计算:每个类别的加权平均值 3.就是添加数据,基值(就是你要计算的值)粗细(就是你要用那个值计算权重)类别(就是你是要乘以那个类别&#x…

前端超分辨率技术应用:图像质量提升与场景实践探索-设计篇

超分辨率! 引言 在数字化时代,图像质量对于用户体验的重要性不言而喻。随着显示技术的飞速发展,尤其是移动终端视网膜屏幕的广泛应用,用户对高分辨率、高质量图像的需求日益增长。然而,受限于网络流量、存储空间和图像…

政安晨:专栏目录【TensorFlow与Keras机器学习实战】

政安晨的个人主页:政安晨 欢迎 👍点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras机器学习实战 希望政安晨的博客能够对您有所裨益,如有不足之处,欢迎在评论区提出指正! 本篇是作者政安晨的专栏《TensorFlow与Keras机器…

linux网络服务学习(4):SAMBA

1.什么是SAMBA SAMBA也是一种文件共享工具 (1)服务名:smb (2)软件名:samba (3)配置文件: /etc/samba/smb.conf /etc/samba/smb.conf.example (4&#…