找到 6705 篇文章 关于数据库
2K+ 阅读量
我们可以使用 ALTER TABLE 语句在现有 MySQL 表的列上添加 FOREIGN KEY 约束。语法 ALTER TABLE 表名 ADD FOREIGN KEY (列名) REFERENCES 带有主键的表(列名); 例如 假设我们想要在表 ‘Orders1’ 上添加一个 FOREIGN KEY 约束,引用具有 ‘Cust_Id’ 列作为主键的表 ‘Customer’。可以使用以下查询来实现: mysql> Alter table orders1 add FOREIGN KEY(Cust_id) REFERENCES Customer(Cust_id); Query OK, 0 rows affected (0.21 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> ... 阅读更多
4K+ 阅读量
我们可以使用 DROP 关键字以及 ALTER TABLE 语句从现有表的多个列中删除复合 PRIMARY KEY 约束。例如 假设我们有一个表 ‘Room_allotment’,在列 ‘ID’ 和 ‘RoomNo’ 上具有复合 PRIMARY KEY 约束,如下所示: mysql> describe room_allotment; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | 0 | | | Name | varchar(20) | NO | PRI | ... 阅读更多
10K+ 阅读量
我们可以使用 ADD 关键字以及 ALTER TABLE 语句在现有表的多个列上设置 PRIMARY KEY 约束。例如 假设我们有一个表 ‘Room_allotment’,如下所示: mysql> Create table Room_allotment(Id Int, Name Varchar(20), RoomNo Int); Query OK, 0 rows affected (0.20 sec) mysql> Describe Room_allotment; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | Id | int(11) | YES | | NULL | | | Name | varchar(20) | YES | | NULL ... 阅读更多
830 阅读量
实际上,MySQL 允许我们在多个列上设置 PRIMARY KEY。这样做的优点是我们可以将多个列作为一个实体来处理。例如 我们创建了表 allotment,并在多个列上定义了复合 PRIMARY KEY,如下所示: mysql> Create table allotment( RollNo Int, Name Varchar(20), RoomNo Int, PRIMARY KEY(RollNo, RoomNo)); Query OK, 0 rows affected (0.23 sec) mysql> Describe allotment; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | RollNo ... 阅读更多
203 阅读量
众所周知,AUTO_INCREMENT 列必须在其上具有 PRIMARY KEY 约束,因此当我们尝试从 AUTO_INCREMENT 列中删除 PRIMARY KEY 约束时,MySQL 会返回有关不正确的表定义的错误消息。以下示例将演示这一点:例如 假设我们有 ‘Accounts’ 表,其描述如下: mysql> Describe accounts; +--------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+----------------+ | Sr | int(10) | NO | PRI | NULL | auto_increment | ... 阅读更多
5K+ 阅读量
我们可以使用 DROP 关键字以及 ALTER TABLE 语句从现有表的列中删除 PRIMARY KEY 约束。例如 假设我们有一个表 ‘Player’,在列 ‘ID’ 上具有 PRIMARY KEY 约束,如下所示: mysql> DESCRIBE Player; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | ID | int(11) | NO | PRI | NULL | | | Name | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 2 rows in ... 阅读更多
344 阅读量
我们可以使用 ALTER TABLE 语句将 PRIMARY KEY 约束应用于现有 MySQL 表的列。语法 ALTER TABLE 表名 MODIFY 列名 数据类型 PRIMARY KEY; 或 ALTER TABLE 表名 ADD PRIMARY KEY (列名); 假设我们有以下名为 ‘Player’ 的表,并且我们想要将 PRIMARY KEY 约束添加到列 ‘ID’,那么可以使用 ALTER TABLE 命令如下: mysql> DESCRIBE Player; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | ... 阅读更多
224 阅读量
众所周知,PRIMARY KEY 列必须具有唯一值并且不能具有空值,因此,如果我们将 UNIQUE 和 NOT NULL 约束都定义在一个列上,那么该列将成为 PRIMARY KEY 列。例如 在此示例中,我们创建了一个表 ‘Student123’,并使用 UNIQUE 和 NOT NULL 约束定义了列 ‘RollNo’。现在,通过描述该表,我们可以看到 ‘RollNo’ 是 PRIMARY KEY 列。 mysql> Create table Student123(RollNo INT UNIQUE NOT NULL, Name varchar(20)); Query OK, 0 rows affected (0.25 sec) mysql> DESCRIBE Student123; +--------+-------------+------+-----+---------+-------+ | Field | Type ... 阅读更多
527 阅读量
当我们多次在同一列上添加 UNIQUE 约束时,MySQL 将在该列上创建索引,次数是我们添加 UNIQUE 约束的次数。例如 假设我们有表 ‘employee’,其中在 ‘empid’ 列上具有 UNIQUE 约束。可以从以下查询中检查: mysql> Describe employee; +------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +------------+-------------+------+-----+---------+-------+ | empid | int(11) | YES | UNI | NULL | | | ... 阅读更多
74 阅读量
多列 UNIQUE 索引的删除方式与从表中删除 UNIQUE 约束相同。例如 在此示例中,使用以下查询,我们已删除了表 ‘employee’ 上的多列 UNIQUE 索引: mysql> DROP index id_fname_lname on employee; Query OK, 0 rows affected (0.30 sec) Records: 0 Duplicates: 0 Warnings: 0 可以从以下查询的结果集中观察到 UNIQUE 索引的删除: mysql> show index from employee; Empty set (0.00 sec) mysql> describe employee; +------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | ... 阅读更多