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

mysql 建表时设置主键

基础概念

MySQL中的主键(Primary Key)是数据库表中用于唯一标识每一条记录的一个或多个字段。主键的作用是确保表中的每一行数据都能被唯一地识别,同时它也是数据库进行索引优化的重要依据。

设置主键的优势

  1. 唯一性:主键保证了表中每一行数据的唯一性,避免了数据的重复。
  2. 快速查找:由于主键通常会被自动建立索引,因此可以通过主键快速定位到特定的记录。
  3. 数据完整性:主键的存在有助于维护数据的完整性和一致性。

主键的类型

  1. 单字段主键:使用单个字段作为主键。
  2. 复合主键:使用多个字段组合起来作为主键。

应用场景

主键广泛应用于各种数据库表的设计中,特别是在需要确保数据唯一性和快速查找的场景下。

如何设置主键

在MySQL中,可以通过以下几种方式设置主键:

单字段主键

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

在这个例子中,id 字段被设置为单字段主键,并且使用了 AUTO_INCREMENT 属性来自动生成唯一的ID值。

复合主键

代码语言:txt
复制
CREATE TABLE orders (
    order_id INT,
    customer_id INT,
    order_date DATE,
    PRIMARY KEY (order_id, customer_id)
);

在这个例子中,order_idcustomer_id 字段的组合被设置为复合主键,确保了每一条订单记录的唯一性。

可能遇到的问题及解决方法

问题:主键冲突

原因:当尝试插入一条新的记录时,如果该记录的主键值已经存在于表中,就会发生主键冲突。

解决方法

  1. 检查并修改数据:在插入数据之前,先检查主键是否已存在,如果存在则进行相应的处理(如更新数据)。
  2. 使用 INSERT IGNOREREPLACE INTO:在插入数据时使用 INSERT IGNORE 可以忽略主键冲突的错误;使用 REPLACE INTO 可以替换掉已存在的记录。
代码语言:txt
复制
-- 使用 INSERT IGNORE
INSERT IGNORE INTO students (id, name, age) VALUES (1, 'Alice', 20);

-- 使用 REPLACE INTO
REPLACE INTO students (id, name, age) VALUES (1, 'Alice', 20);

问题:主键选择不当

原因:如果选择了不合适的字段作为主键,可能会导致性能问题或数据冗余。

解决方法

  1. 选择唯一且稳定的字段:作为主键的字段应该具有唯一性,并且其值不应该频繁更改。
  2. 避免使用业务相关的字段:主键应该尽量与业务逻辑无关,以避免因业务需求变更而导致主键需要修改。

参考链接

通过以上内容,你应该对MySQL中设置主键的基础概念、优势、类型、应用场景以及可能遇到的问题和解决方法有了全面的了解。

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

相关·内容

oracle主键、外键基本语法

主键:唯一标识,不能为空,加快查询速度,自动创建索引 外键:约束内的数据的更新,从定义外键可以发现 外键是和主键联系,数据类型要统一,长度(存储大小)要统一。...这样在更新数据的时候会保持一致性 -创建表格语法: create table 名( 字段名1 字段类型(长度) 是否为空, 字段名2 字段类型 是否为空...); -增加主键 alter table 名 add constraint 主键名 primary key (字段名1); -增加外键: alter table 名...add constraint 外键名 foreign key (字段名1) references 关联 (字段名2); 在建立表格就指定主键和外键 create table...varchar2(8) not null, constraint PK_T_STU primary key (STU_ID) ); 主键和外键一起建立

3.1K50

mysql自增主键设置

mysql自增主键设置 在数据库应用中,经常希望在每次插入新纪录,系统自动生成字段的主键值。可以通过为主键添加AUTO_INCREMENT关键字来实现。...默认情况下,在MYSQL中AUTO_INCREMENT的初始值是1,每新增一条记录,字段值自动加1.一个只能有一个字段属用AUTO_INCREMENT约束,且该字段必须为主键的一部分。...AUTO_INCREMENT约束的字段可以是任何整数类型(TINTINT、SMALLINT、INT、BIGINT等) 设置的属性值自动增加的语法规则如下: 字段名 数据类型 AUTO_INCREMENT...创建,指定编号自动递增 create table tb_emp8( id int(11) PRIMARY KEY auto_increment, name VARCHAR(25) not null...FLOAT ); 执行插入语句: insert into tb_emp8(name,salary) values('lucy',1000),('lura',1200),('kevin',1500); 查看数据

11.1K30
  • 领导大怒:不加主键的都是耍流氓

    MySQL在创建,如果你没有显示的创建主键,那么innodb会自动帮你创建一个不可见的、长度是6字节的row_id,所有未定义主键共享该row_id,每次插入一条数据row_id加1。...在创建,DBA一般都会建议一定要在这个上显示的定义一个主键,那么如果没有创建主键会有哪些影响呢,今天我们就来说一下主键在主从复制中的影响以及如何选择主键。...> update t set name='主键测试,结果验证' where id <10000; 从库检查延迟情况 mysql> show slave status\G ****************...在ROW模式下,在主库上进行一次全扫描,但是在从库上则是一条条的进行更新,由于没有主键和索引,就会导致在从库进行N次全扫描,这样也就拖慢了从库APPLY的效率。...在分布式数据库中可以采用自增ID作为物理主键,UUID作为逻辑主键的方案,或者自定义实现主键值的获取,来保证分库分后的全局唯一性,比如淘宝的分布式数据库中间件TDDL提供的Sequence解决方案等。

    1.9K20

    mysql 设置主键命令_MySQL常用命令

    ,那么password字段要改成authentication_string 创建数据库用户: 单纯的创建:create user ‘name’@‘host’ identified by ‘密码’ 创建设置用户权限...insert into test(id) values(1002); #此处注意如果字段值设置为char字符型的,需要将values值加双引号 批量插入数据:insert into test values...test to nameinfo; 8、主键创建 方式一: 创建创建主键:create table test(id int(10),name char(20),primary key id);...方式二: 创建完之后添加主键:alter table userinfo add primary key (id); 删除主键:alter table userinfo drop primary key...; 9、创建索引 方式一: 创建创建索引:create table test(id int(10),name char(20),primary key id,key ‘index_name’ (‘name

    3.8K20

    粗聊Mysql——你会么?

    本文中说到的“”,并非单纯的一个库,或是一张,而是你建好的库和在项目的运营中,是否能应付各种事件,下面我说说几个我在项目中遇到的问题以及处理的方法,算是一个小小的心得,给大家分享下。...一、两之间若有关联,你是否还在用主键进行关联?   ...比如现在有2张,一张新闻栏目,一张新闻,现在两张需要进行关联,我想大多数人的做法肯定是在新闻表里一个新闻栏目id,然后把新闻栏目表里的主键ID(自增)写到这个字段里,通过这样进行两关联。   ...这样就会造成一种情况,如果那天对数据库进行优化,把主键进行了重新排序(暂时没有找到mysql优化软件会优化主键,但是可以通过代码删除主键,然后从新建立自增主键来实现主键重新排序),那就彻底杯具了,栏目和文章完全对不上号了...所以我建议两之间关联不用主键,而是单独一个编号的字段,我们这里可以用mysql的uuid()函数做为编号,相关文献可以参考《UUID做主键好还是不好》,只所以一张要2个主键,一个物理主键(自增id

    5.2K10

    MySQL为什么要给加上主键

    1.一个没加主键,它的数据无序的放置在磁盘存储器上,一行一行的排列的很整齐. 2.一个加了主键,并不能被称之为「」。...如果给上了主键,那么在磁盘上的存储结构就由整齐排列的结构转变成了树状结构,并且是「平衡树」结构,换句话说,就是整个就变成了一个索引。...这就是为什么一个只能有一个主键,一个只能有一个「聚集索引」,因为主键的作用就是把「」的数据格式转换成「索引(平衡树)」的格式放置。   ...  这样展现出来的图形如下:   实际上,我们还有更狠的操作,直接关闭坐标轴:   plt.axis("off"www.jintianxuesha.com)   结果如下:   范围设置...不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql

    2.5K20

    MySQL 系列教程之(五)DDL 操作:

    MySQL数据。.../public/img/pic.jpg' )engine=innodb default charset=utf8; 实例解析: 如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL, 在操作数据库如果输入该字段的数据为...AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。 PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。...查看表结构 desc stu; 查看表语句 show create table stu\G 修改结构 格式: alter table 名 action(更改选项); 添加字段: 添加字段:alter...删除 MySQL中删除数据是非常容易操作的, 但是你再进行删除操作要非常小心,因为执行删除命令后所有数据都会消失。 DROP TABLE table_name ;

    7.7K73

    MySQL 中非主键列溢出情况监控

    之前踩到过MySQL主键溢出的情况,通过prometheus监控起来了,具体见这篇MySQL主键溢出复盘 这次遇到的坑,更加的隐蔽。 是一个log表里面的一个int signed类型的列写满了。...快速的解决方法当然还是只能切新来救急了,然后搬迁老表的部分历史数据到热表。  亡羊补牢,处理完故障后,赶紧写脚本把生产的其他都捋一遍。...')')  from information_schema.COLUMNS where TABLE_SCHEMA NOT IN ('information_schema','sys','test','mysql.../bin/bash # 监测int类型的当可用空间少500w的时候,提醒做DDL操作  # 设置 session级别的 max_execution_time为2秒,防止没有索引的大的拖慢数据库,但是这样可能漏判部分列...NULL" ]]; then     continue    fi    if [ ${ret} -lt 5000000 ] ; then        echo "$line 剩余空间 ${ret}, 该可用水位不足

    2K10

    老大问我:“为啥还设置个自增 id ?用流水号当主键不正好么?”

    这不,开始对流程及结构了。 我:吧啦吧啦吧啦 …… 老大:这个为啥还设置个自增 id ?直接用流水号(用户号/产品号)当主键不就行了?...1 规约 ? Java 开发手册-嵩山版 在工作中,创建的时候,DBA 也会审核一下 SQL,检查是否符合规范以及常用字段是否设置索引。...主键的特征 ? 简而言之: 非空、唯一、少更改或不更改 。 如何添加主键 ? 可以在 create 创建的时候指定,也可以使用 alter 语句后面添加主键,不过官方建议在创建就指定。...为什么要添加主键 主键可以唯一标识这一行数据,从而保证在删除更新操作,只是操作这一行数据。 索引需要,每个 InnoDB 又有一个特殊的索引,即聚簇索引,用来存储行数据。...索引的分类 聚簇索引:存储是根据主键列的值组织的,以加快涉及主键列的查询和排序。在介绍主键也对聚簇索引进行了介绍。 二级索引:也可以叫辅助索引,在辅助索引中会记录对应的主键列以及辅助索引列。

    1.9K20

    MySQL 案例:无主键产生的延迟

    本文围绕同步延迟的场景之一:无主键,来看看延迟产生的原因,以及应对的策略。当然,从标题上也能看出来,给主键是最好的办法,不过在关于这个问题,其实还有一些其他的方式可以尝试。...一个 MySQL 的参数 MySQL 在这类场景下,有一个专门的参数来调整从库定位数据的方法:slave_rows_search_algorithms 参考官方文档的参数设置: 索引类型/参数值 INDEX_SCAN...测试一下 本次测试环境使用腾讯云数据库 MySQL,配置为 4 核 8GB 内存。测试数据使用 sysbench 生成,单 2000 万行数据,且没有主键和唯一索引。...测试修改了 binlog_row_image 的值为 FULL,因为腾讯云数据库 MySQL 默认设置为 MINIMAL 来节省磁盘空间,但是这个参数在一定程度上会影响 slave_rows_search_algorithms...考虑到腾讯云数据库 MySQL 的默认设置,Hash Scan 对于“粗心”的用户是相对好一些的选择。

    3.2K132

    老大问我:“为啥还设置个自增 id ?用流水号当主键不正好么?”

    这不,开始对流程及结构了。 我:吧啦吧啦吧啦 …… 老大:这个为啥还设置个自增 id ?直接用流水号(用户号/产品号)当主键不就行了?...1 规约 Java 开发手册-嵩山版 在工作中,创建的时候,DBA 也会审核一下 SQL,检查是否符合规范以及常用字段是否设置索引。...主键的特征 简而言之: 非空、唯一、少更改或不更改 。 如何添加主键 可以在 create 创建的时候指定,也可以使用 alter 语句后面添加主键,不过官方建议在创建就指定。...索引的分类 聚簇索引:存储是根据主键列的值组织的,以加快涉及主键列的查询和排序。在介绍主键也对聚簇索引进行了介绍。 二级索引:也可以叫辅助索引,在辅助索引中会记录对应的主键列以及辅助索引列。...同时在建除了要设置一个自增 id 用来当做主键,小伙伴们在业务开发过程中是否也会遇到一种情况:用户的注销,数据的删除等都是进行的逻辑删除,而不是物理删除。

    86630

    MySQL【第二章】——&&约束

    一、数据类型   MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。...date: yyyy/MM/dd     time: HH/mm/ss     datetime: yyyy/MM/dd/HH/mm/ss     timestamp: 1970-01-01  二、...&约束 1.约束   1.1 主键约束(PRIMARY KEY)     主键约束:唯一、不重复、不为空;每个都应该有一个主键,并且每一个只能有一个主键。    ...例如:   1) 性别:sex char(1) default '男'     2) 日期:createdate timestamp default current_timestamp 2....KEY 约束名;   3)新增主键:   ALTER TABLE 名 ADD PRIMARY KEY(主键名称);   4)删除主键主键只有一个直接删除即可   ALTER TABLE

    4.8K20

    mysql常见的选项和约束

    create table选项 指定列选项:default 当插入一个新行到中并且没有给该列明确赋值,如果定义了列的默认值,将自动得到默认值 ;如果没有,则为null。...约束主要是防止非法数据进入中,保证数据的正确性和一致性,统称为数据完整性 约束也可以防止一个被删除 MySQL的约束保存在information_schema.table_constraints中...,类型一般为整型或者字符串 具有主键约束的列不允许有null值,不允许有重复值 每个最多只允许一个主键,可定义联合主键主键名总是PRIMARY 联合主键 用几个列来进行唯一标识一行 constraint...null值 父子表 外键所在的叫做子表,从 外键所引用的主键所在的叫做父,主表 constraint emp_deptid_fk foreign_key(deptid) references...,而是将子行的外键设置为null 外键引用定义 reference_definition: REFERENCES tbl_name (index_col_name,...)

    14410
    领券