12、MySQL数据库表设计与数据插入全解析

MySQL数据库表设计与数据插入全解析

1. 表设计基础

在数据库设计中,并非所有类都需要对应创建表。例如,对于“Person”类,由于“customer”表已包含所需的全部数据,所以无需为“Person”创建表。而且,有时我们会创建代码中不存在对应类的表,这表明类与表之间的关系是非常灵活的。

2. 数据库中的键和约束

当我们定义好主表后,需要考虑表内数据的情况。表中的每一行描述一个对象,可能是书籍或客户。若应用程序出现漏洞,允许创建具有相同数据的书籍或客户,数据库该如何区分它们呢?理论上,我们会为客户分配ID以避免这种情况,但如何确保ID不重复呢?

MySQL提供了一种机制,可对数据施加特定限制。除了常见的“NOT NULL”或“UNSIGNED”等属性外,还可以指定某些字段具有特殊性质,并为其添加特定行为。这些机制被称为键,主要有四种类型:主键、唯一键、外键和索引。

2.1 主键

主键是用于唯一标识表中一行数据的字段。在同一表中,主键的值不能重复,且不能为“NULL”。为定义对象的表添加主键几乎是必要的,因为它能确保我们始终可以通过该字段区分两行数据。

主键的一个吸引人的特性是可以将其设置为自增的数值。也就是说,无需手动为ID赋值,MySQL会自动获取最新插入的ID并加1,就像我们使用“Unique”特性一样。当然,要实现这一点,字段的数据类型必须为整数。实际上,我们强烈建议始终将主键定义为整数类型,即使现实中的对象本身并没有这样的ID。原因是通过这个唯一的数值ID搜索行,MySQL会对该字段进行性能优化。

以下是为“book”表添加ID作为主键的操作步骤:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值