首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql添加主键列

基础概念

MySQL中的主键(Primary Key)是一种约束,用于唯一标识表中的每一行记录。主键列必须满足以下条件:

  1. 唯一性:主键列中的每个值必须是唯一的。
  2. 非空性:主键列中的值不能为空。
  3. 单一性:一个表只能有一个主键。

添加主键列的优势

  1. 唯一标识:主键可以唯一标识表中的每一行记录,便于数据检索和更新。
  2. 数据完整性:通过主键约束,可以确保数据的唯一性和完整性。
  3. 索引优化:主键列默认会创建一个唯一索引,可以提高查询效率。

类型

MySQL中的主键可以是以下几种类型:

  1. 单列主键:表中只有一列作为主键。
  2. 复合主键:表中有多列组合成一个主键。

应用场景

主键广泛应用于各种数据库设计中,特别是在需要唯一标识记录的场景中,如用户表、订单表等。

添加主键列的步骤

假设我们有一个表 users,结构如下:

代码语言:txt
复制
CREATE TABLE users (
    id INT,
    name VARCHAR(50),
    email VARCHAR(50)
);

我们可以通过以下步骤添加主键列:

方法一:修改表结构

代码语言:txt
复制
ALTER TABLE users ADD PRIMARY KEY (id);

方法二:创建新表并插入数据

代码语言:txt
复制
CREATE TABLE users_new (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    email VARCHAR(50)
);

INSERT INTO users_new (id, name, email)
SELECT id, name, email FROM users;

DROP TABLE users;
RENAME TABLE users_new TO users;

遇到的问题及解决方法

问题:主键冲突

原因:尝试插入的数据与已有数据的主键值重复。

解决方法

  1. 检查数据:确保插入的数据在主键列上是唯一的。
  2. 使用 INSERT IGNORE:忽略主键冲突的插入操作。
代码语言:txt
复制
INSERT IGNORE INTO users (id, name, email) VALUES (1, 'Alice', 'alice@example.com');
  1. 使用 ON DUPLICATE KEY UPDATE:在主键冲突时更新现有记录。
代码语言:txt
复制
INSERT INTO users (id, name, email) VALUES (1, 'Alice', 'alice@example.com')
ON DUPLICATE KEY UPDATE name = 'Alice', email = 'alice@example.com';

参考链接

MySQL官方文档 - 主键

希望以上信息对你有所帮助!如果有更多问题,欢迎继续提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • mysql多字段主键_sql改变数据类型

    MySQL数据类型 (1)数值类型 1、整数型 2、浮点型 3、定点型 (2)日期时间类型 (3)字符串类型 MySQL字段属性 1、空\不为空值:NULL、NOT NULL 2、主键:primary...存储文字,当字符大于255时,一般使用text; mediuntext L+3 中等长度文本数据 longtext L+4 极大文本数据 不要轻易的使用最大限度来存储字符串,因为涉及记录长度问题 : MySQL...因为唯一标识,所以主键字段的数据不能为空,并且主键字段的数据值不能重复 主键也是一种索引,可以提高查找速率。...主键的用途:主键的主要用途是用来唯一标识每一条记录,比如我们想将两个表(学生表跟老师表)的多对多关系封装到一个表中,这个抽取的映射字段一般都是各自的主键。...唯一键可以约束字段,使得字段的数据不能重复 如果唯一键同时也有not null,并且表中没有主键的话,在desc查看表结构中会显示成主键 如果唯一键也不允许为空,那么功能与主键相同 唯一键的定义方法可以参考主键

    2.5K20

    MySQL如何给JSON添加索引(二)

    上一篇文章《MySQL 8.0 JSON增强到底有多强?...(一)》,我们简单介绍了MySQL中JSON数据类型,相信大家对JSON数据类型有了一定的了解,那么今天我们来简单看下如何在JSON列上添加索引? InnoDB支持虚拟生成的二级索引。...二级索引可以在一个或多个虚拟列上创建,也可以在虚拟和常规或存储的生成的组合上创建。包含虚拟的二级索引可以定义为UNIQUE。 在虚拟生成的列上创建辅助索引时,生成的值将在索引的记录中具体化。...在虚拟列上添加或删除二级索引是就地操作。 通过索引生成以提供JSON索引 JSON 不能直接对进行索引。...要创建间接引用此类的索引,可以定义一个生成,该提取应建立索引的信息,然后在生成的列上创建索引,如下所示: 说明:8.0和5.7都支持在生成列上添加索引 mysql>CREATE TABLE jemp

    7.4K11

    mysql 联合主键_Mysql 创建联合主键

    char(8), cc date, primary key (aa,bb ) ); aa,bb为联合主键 不知道是不是因为mysql(6.0)的版本问题,还是各版本都是这种情况,mysql中创建联合主键...,联合主键列名之外不可以用单引号括上,否则出现错误,无法创建,报错是该在表中不存在。...创建,添加主键 primary key 1.最简单的: CREATE TABLE t1( id int not null, name char(20)); 2.带主键的: a:CREATE...COMMENT ‘主键编号’, `IP` … mysql修改联合主键 参考 https://blog.csdn.net/BockSong/article/details/80933477 alter...联合索引 我们都知道在一个表中当需要2以上才能确定记录的唯一性的时候,就需要用到联合主键,当建立联合主键以后,在查询数据的时候性能就会有很大的提升,不过并不是对联合主键的任何单独查询的时候性能都会提升

    8.3K20

    技术译文 | MySQL 添加主键可以节省磁盘空间吗?

    MySQL 表定义主键不是必须的,并且直到今天(MySQL 版本 8.3.0)都是这样。不过,在 MGR 和 PXC 架构中不允许使用没有主键的表。...之前,在没有主键的情况下,当两都通过辅助键建立索引时,我们可以看到以下内容: mysql > select SPACE,INDEX_ID,i.NAME as index_name, t.NAME as...,它将添加一个名为 的内部主键 GEN_CLUST_INDEX。...因此,即使有问题的表中没有任何现有是唯一的,最好还是添加另一个唯一作为主键。...但是,如果由于遗留应用程序问题而无法添加新的主键,建议使用不可见的主键(GIPK)来当作主键。这样,您将获得性能优势,同时对应用程序是不可见的。

    12810

    mysql 主键自增语句_MySQL 自增主键

    自增主键的单调性 为何会有单调性的问题? 这主要跟自增主键最大值的获取方式,以及存放位置有关系。 如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...自增主键最大值怎么取的?存放到哪里?...MySQL 5.7 及之前的版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

    10.8K10

    Mysql资料 主键

    主键(primary key) 一(或一组),其值能够唯一区分表中的每个行。 唯一标识表中每行的这个(或这组)称为主键。...表中的任何都可以作为主键,只要它满足以下条件: 1、任何两行都不具有相同的主键值 2、每个行都必须具有一个主键值(主键不允许NULL值) 除MySQL强制实施的规则外,应该坚持的几个普遍认为的最好习惯为...: 1、不更新主键的值 2、不重用主键的值 3、不在主键中使用可能会更改的值(例如,如果使用一个名字作为主键以标识某个供应商,应该供应商合并和更改其名字时,必须更改这个主键) 总之:不应该使用一个具有意义的...二.操作 创建表中添加自增主键: create table s1 (id int(11) AUTO_INCREMENT PRIMARY KEY ; 增加主键: ALTER TABLE s2 ADD PRIMARY.../16),则开辟一个新的页(节点) 1.如果表使用自增主键,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的页。

    3.8K20

    mysql主键自增策略_MySQL 自增主键机制

    自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪? 不同的存储引擎保存自增值的策略不一样; a....Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...每次重启后第一次打开表,都会去查找自增值的最大值max(id), 并设置表当前自增值为max(id) + 1; mysql8.0, 自增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4. 自增锁的优化 a....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 的策略(注:该策略是导致自增 id 不连续的第三种原因

    9.5K50

    MySQL主键详解

    主键(primary key) 一 (或一组),其值能够唯一区分表中的每个行。唯一标识表中每行的这个(或这组)称为主键主键用来表示一个特定的行。...表中的任何都可以作为主键,只要它满足以下主键值规则条件: 任两行不具相同的主键值 每行都必须具有一个主键值(主键不允许NULL) 这里的规则是MySQL本身强制实施的。...除MySQL强制实施的规则外,还应该坚持的最佳实践: 不更新主键中的值 不重用主键的值 不在主键中使用可能会更改的值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...联合主键体现在多个表上,复合主键体现在一个表中的多个字段。 复合主键 主键通常定义在表的一上,但这并不是必需的,也可使用多个列作为主键。...此时上述的条件必须应用到构成主键的所有,所有值的组合必须是唯一的(多中的单个的值可以不唯一)。

    4.9K20

    MySQL主键设计盘点

    最近在项目中用了UUID的方式生成主键,一开始只是想把这种UUID的方式生成主键记录下来,在查阅资料的过程中,又有了一些新的认识和思考。 主键定义 唯一标识表中每行的一个(或一组)称为主键。...主键设计和应用原则 除了满足MySQL强制实施的规则(主键不可重复;一行中主键不可为空)之外,主键的设计和应用应当还遵守以下公认的原则: 不更新主键中的值; 不重用主键的值; 不在主键中使用可能会更改的值...关于MySQL 使用自增ID主键和UUID 作为主键的性能比较可以查看参考【8】。 结论: 1、uuid做主键适用于小规模分布式架构用。...2、在使用uuid作为主键的时候,最好设计createtime(创建时间)和modifytime(修改时间)以应付可能的排序等场景。...结论: 用自建的id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql

    4.2K30

    MySQL主键约束使用

    MySQL主键约束是一种用于确保表中每行数据的唯一性的限制。每个表只能有一个主键,它可以是一个或多个。创建表时添加主键约束在创建表时添加主键约束,需要在列名后面添加关键字"PRIMARY KEY"。...,"id"被指定为主键,而"name"和"age"不是。...这意味着在插入数据时,必须确保"id"的值唯一,否则将会出现错误。在已经存在的表中添加主键约束如果已经存在一个表,但需要将某些或字段添加主键约束,可以使用ALTER TABLE语句来修改表结构。...例如,以下是向已经存在的表中添加主键约束的示例:ALTER TABLE my_tableADD PRIMARY KEY (id);在上面的示例中,"id"被指定为主键。...这意味着在插入数据时,无需提供"id"的值,MySQL会自动为其分配一个唯一的值。示例假设有一个用户表,其中包含以下列:id、name和email。

    2.6K20

    PBI-基础入门:添加与新建(计算

    小勤:在Power BI里怎么增加一? 大海:在Power BI里增加列有2种方法,一种是咱们在学Power Query里的“添加”方法,还有一种是在PowerPivot里的新建“计算”方法。...具体操作方法如下: 在查询编辑中添加: 直接在Power BI Desktop界面中新建: 小勤:啊。Power BI真是两这个的完全组合啊。这两者之间有什么不同吗?...但在构造的时候是有以下差别的: 查询编辑器里添加用的是Power Query的知识,一般情况下,Power Query在这方面的功能比较强一些,尤其是做文本的相关处理时。...但是,新建计算的方法有个好处,是可以直接引用计算度量的相关结果,这一点是用PQ添加方法做不到的。 小勤:那该怎么决定到底用哪一种方法呢? 大海:我很少纠结这个问题,反正觉得哪个用起来方便就用哪个。...总的来说,我一般是除非要引用某些计算度量的结果或者是一些非常简单的计算,绝大部分的时候我都是用PQ进行处理的。 小勤:嗯。我大概知道了。

    7.3K30

    Mysql:小主键,大问题

    本篇讲解 Mysql 的「主键」问题,从「为什么」的角度来了解 Mysql 主键相关的知识,并拓展到主键的生成方案问题。再也不怕被问到 Mysql 时只知道 CRUD 了。...那么为什么长主键在「索引」中会影响性能? ? 上面是 Innodb 的索引数据结构。左边是「聚簇索引」,通过主键定位数据记录。右边是「二级索引」,对数据做索引,通过数据查找数据主键。...如果表使用自增主键,那么每次插入新的记录,记录就会「顺序添加」到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的页。这样就会形成一个「紧凑」的索引结构,近似顺序填满。...Key 往往更小,性能更优 逻辑 Key 更容易保证唯一性 更易于优化 逻辑 Key 缺点 查询主键主键索引需要额外的磁盘空间 在插入数据和更新数据时需要额外的 IO 更多的 join 可能 如果没有唯一性策略限制...一般情况下,我们都使用 Mysql 的自增 ID,来作为表的「主键」,这样简单,而且从上面讲到的来看,性能也是最好的。

    3.8K10
    领券