史上最简单的 MySQL 教程(十四)「列属性 之 主键」

主键

主键:primary key表中主要的键,每张表只能有一个字段(复合主键,可以多个字段)使用此属性,用来唯一的约束该字段里面的数据,不能重复

增加主键

在 SQL 操作中,有 3 种方法可以给表增加主键,分别为:

第 1 种:在创建表的时候,直接在字段之后,添加primary key关键字

-- 增加主键
create table my_pri1(
    name varchar(20) not null comment ‘姓名‘,
    number char(10) primary key comment ‘学号‘
)charset utf8;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

如上图所示,此方法的优点是清晰明了,缺点则是只能使用一个字段作为主键。

第 2 种:在创建表的时候,在所有的字段之后,使用primary key(主键字段列表)来创建主键(如果有多个字段作为主键,则称之为复合主键)

-- 复合主键
create table my_pri2(
    number char(10) not null comment ‘学号‘,
    course char(10) not null comment ‘课程编号‘,
    score tinyint unsigned default 60,
    -- 增加主键限制,学号和课程编号应该是对应的,具有唯一性
    primary key(number,course)
)charset utf8;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

第 3 种:当表创建完之后,额外追加主键,可以直接追加主键,也可以通过修改表字段的属性追加主键

-- 追加主键
create table my_pri3(
    course char(10) not null comment ‘课程编号‘,
    name varchar(10) not null comment ‘课程名称‘
)charset utf8;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

在这里,追加主键有两种方式,分别为:

  • alter table my_pri3 modify course char(10) primary key comment ‘课程编号‘; -- 不建议使用
  • alter table my_pri3 add primary key(course); -- 推荐使用

如上图所示,咱们追加主键成功。不过,想要用此方法,有一个前提,那就是:表中对应字段的数据是不重复的,即保证唯一性

主键约束

主键约束,即主键对应的字符中的数据不允许重复,如果重复,则数据操作(主要是增和改)失败

-- 主键约束(冲突)测试
insert into my_pri3 values(‘MATH00123‘,‘泛函分析‘);
insert into my_pri3 values(‘MATH00123‘,‘非线性分析‘);
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

更新主键 & 删除主键

对于主键,没有办法直接更新,主键必须先删除,然后才能更新。

  • 基本语法:alter table + 表名 + drop primary key;

执行如下 SQL 语句,进行测试

-- 删除主键
alter table my_pri3 drop primary key;
  • 1
  • 2
  • 1
  • 2

如上图所示,咱们已经成功删除表my_pri3的主键啦!想要增加主键,只需要通过前面讲的 3 种方法即可。

主键分类

根据主键的字段类型,咱们可以将主键分为两类,分别为:

时间: 2024-11-04 16:36:19

史上最简单的 MySQL 教程(十四)「列属性 之 主键」的相关文章

史上最简单的 SpringCloud 教程 | 终章

版权声明:本文为博主原创文章,欢迎转载,转载请注明作者.原文超链接 ,博主地址:http://blog.csdn.net/forezp. 目录(?)[+] 转载请标明出处: http://blog.csdn.net/forezp/article/details/70148833 本文出自方志朋的博客 错过了这一篇,你可能再也学不会 Spring Cloud 了!Spring Boot做为下一代 web 框架,Spring Cloud 作为最新最火的微服务的翘楚,你还有什么理由拒绝.赶快上船吧,老

史上最简单的 MyBatis 教程

1 前言 MyBatis 源于 Apache 的一个开源项目 iBatis,而 iBatis 一词则来源于"internet"和"abatis"的组合,2010年这个项目由 Apache Software Foundation 迁移到了 Google Code,并且改名为MyBatis ,2013年11月其又迁移到 Github.MyBatis 是一个基于 Java 的支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架,相比于基于面向对象使用 HQL 语言的

史上最简单的SpringCloud教程 | 第十篇: 高可用的服务注册中心

最新Finchley版本请访问:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f10-eureka/或者http://blog.csdn.net/forezp/article/details/81041101 文章 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现(Eureka) 介绍了服务注册与发现,其中服务注册中心Eureka Server,是一个实例,当成千上万个服务向它注册的时候,它的负载是非常高的,

史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现(Eureka)

最新Finchley版本请访问:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f1-eureka/或者http://blog.csdn.net/forezp/article/details/81040925 spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选.分布式会话等等.它运行环境简单,可以在开发人员的电脑上跑.另外说明spring cl

MySQL数据库8(九)列属性之主键、自增长

主键 顾名思义,主要的键,primary key,在一张表中,有且只有一个字段,里面的值具有唯一性 创建主键 随表创建 系统提供了两种增加主键的方式: 1.直接在需要当做主键的字段之后,增加primary key属性来确定主键 2.在所有字段之后增加primary key选项:primary key(字段信息) 表后增加 基本语法:alter table 表名 add primary key(字段); 查看主键 方案1: 查看表结构 方案2:查看表的创建语句 删除主键 基本语法:alter ta

史上最简单的 SpringCloud 教程 | 第十四篇: 服务注册(consul)

这篇文章主要介绍 spring cloud consul 组件,它是一个提供服务发现和配置的工具.consul具有分布式.高可用.高扩展性. consul 具有以下性质: 服务发现:consul通过http 方式注册服务,并且服务与服务之间相互感应. 服务健康监测 key/value 存储 多数据中心 consul可运行在mac windows linux 等机器上. linux windows下安装:见consul怎么在windows下安装 构建一个consul-miya的springboot

[分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)

踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-355923-1-4.html 学会封装,只需要掌握十个步骤.五分钟包你学会,不会不交学费~ 适合人群: 1.会装系统 2.了解PE的使用 3.对注册表有初步的了解 所需工具: 1.Windows系统镜像 2.PE(可以放到U盘,如果使用虚拟机封装系统,直接下载PE镜像即可) 3.磁盘清理工具(如Windows7瘦身工具.自由天空系统清理&减肥程序.注册表减肥工具等) 4.驱动包(如万

史上最简单的SpringCloud教程 | 第五篇: 路由网关(zuul)(Finchley版本)

在微服务架构中,需要几个基础的服务治理组件,包括服务注册与发现.服务消费.负载均衡.断路器.智能路由.配置管理等,由这几个基础组件相互协作,共同组建了一个简单的微服务系统.一个简答的微服务系统如下图: 注意:A服务和B服务是可以相互调用的,作图的时候忘记了.并且配置服务也是注册到服务注册中心的. 在Spring Cloud微服务系统中,一种常见的负载均衡方式是,客户端的请求首先经过负载均衡(zuul.Ngnix),再到达服务网关(zuul集群),然后再到具体的服.,服务统一注册到高可用的服务注册

史上最简单的SpringCloud教程 | 第三篇: 服务消费者(Feign)

最新Finchley版本请访问:https://www.fangzhipeng.com/springcloud/2018/08/30/sc-f3-feign/或者http://blog.csdn.net/forezp/article/details/81040965 上一篇文章,讲述了如何通过RestTemplate+Ribbon去消费服务,这篇文章主要讲述如何通过Feign去消费服务. Feign是一个声明式的伪Http客户端,它使得写Http客户端变得更简单.使用Feign,只需要创建一个接