Heim  >  Artikel  >  Datenbank  >  Was sind die Konzepte von MySQL-Einschränkungen und -Indizes?

Was sind die Konzepte von MySQL-Einschränkungen und -Indizes?

WBOY
WBOYnach vorne
2023-05-26 10:04:491284Durchsuche

1. Regeln für den relationalen Datenbankentwurf

Folgen Sie dem ER-Modell und den drei Paradigmen

  • E-Entität stellt die Entität dar, die einer Tabelle in der Datenbank entspricht

  • R-Beziehung stellt die Beziehung dar

drei Paradigmen:

1. Spalten können nicht geteilt werden

3. Beziehungsreferenz-Primärschlüssel

Konkrete Verkörperung

    Fügen Sie die Daten in die Tabelle ein und stellen Sie sie dann in die Bibliothek.
  • Eine Datenbank kann mehrere Tabellen haben, und jede Tabelle hat einen Namen, um sich selbst zu identifizieren. Tabellennamen sind eindeutig.
  • Tabellen haben einige Eigenschaften, die definieren, wie Daten in der Tabelle gespeichert werden, ähnlich dem Design von „Klassen“ in Java und Python.
  • Tabelle besteht aus Spalten, die wir auch Felder nennen. Das Design der Datentabelle ist eigentlich das Design und die Beschreibung der Bedeutung jedes Feldes. Beim Erstellen einer Datentabelle müssen Sie den Datentyp für jedes Feld angeben sowie deren Datenlänge und Benennung definieren. Jedes Feld ähnelt einem „Instanzattribut“ in Java oder Python.
  • Die Daten in der Tabelle werden in Zeilen gespeichert, und eine Zeile ist ein Datensatz. Jede Zeile ähnelt einem „Objekt“ in Java oder Python.

Was sind die Konzepte von MySQL-Einschränkungen und -Indizes? 2. Die Konzepte der Datenintegrität, Einschränkungen und Indizes

1. Datenintegrität (Datenintegrität) bezieht sich auf die Genauigkeit (Accuracy) und Zuverlässigkeit (Reliability) der Daten Die Datenbank enthält Daten, die nicht den semantischen Vorschriften entsprechen, und vermeidet gleichzeitig ungültige Vorgänge oder Fehlermeldungen, die durch die Eingabe und Ausgabe von Fehlerinformationen verursacht werden.

Die Integrität der Daten sollte im Folgenden berücksichtigt werden vier Aspekte:

    Entitätsintegrität: Beispielsweise können nicht zwei identische und nicht unterscheidbare Datensätze in derselben Tabelle vorhanden sein
  • Domänenintegrität: Beispiel: Altersbereich 0-120, Geschlechtsbereich „männlich/weiblich“
  • Zitatintegrität (Referenzielle Integrität): Zum Beispiel: die Abteilung, in der sich der Mitarbeiter befindet, diese Abteilung muss in der Abteilungstabelle gefunden werden
  • Benutzerdefinierte Integrität (Benutzerdefinierte Integrität): Zum Beispiel: der Benutzername ist eindeutig, das Passwort darf nicht leer sein usw. Das Gehalt des Managers dieser Abteilung darf nicht höher sein als das Fünffache des Durchschnittsgehalts der Mitarbeiter in dieser Abteilung.
  • Zur Umsetzung werden Einschränkungen verwendet und bewahren Sie die Datengeschäftsregeln und die Datenintegrität auf. Einschränkungen können als Datenbankobjekte behandelt werden. Sie sind logische Einschränkungen und belegen keinen zusätzlichen Platz 3. Index (INDEX)

  • Der Index ist eine Datenbankstruktur, die einzeln und physisch auf einer Datenseite gespeichert wird. Es handelt sich um eine Sammlung von einem oder mehreren Spaltenwerten in einer Tabelle und einer entsprechenden Liste logischer Zeiger zu den physischen Identifikationsdatenseiten der Datenwerte in der Tabelle (ähnlich der Verzeichnisindexseite des Xinhua-Wörterbuchs). Das Vorhandensein des Index erhöht den Speicherplatz der Datenbank und erhöht den Zeitaufwand für das Einfügen und Ändern Daten (da sich der Index auch ändert, wenn Daten eingefügt und geändert werden), kann jedoch die Abfragegeschwindigkeit erheblich verbessern. Daher sollten Indizes für Schlüsselspalten oder andere Spalten erstellt werden, die häufig abgefragt, sortiert und durchsucht werden nach Bereich. Für Spalten, die in Abfragen selten verwendet und referenziert werden, für Spalten, die sehr häufig geändert werden, und für Spalten mit wenigen Werten (z. B. gibt es für das Geschlecht nur „männlich“ und für Spalten wie „weiblich“ sollten keine Indizes erstellt werden).

①Mysql erstellt automatisch Indizes für die Primärschlüssel-, Einzelschlüssel- und Fremdschlüsselspalten. Wenn andere Spalten indiziert werden müssen, müssen diese manuell erstellt werden.

②Der Primärschlüssel wird gelöscht und der entsprechende Index wird auch gelöscht

③Die Möglichkeit, einen eindeutigen Schlüssel zu löschen, besteht darin, den entsprechenden Index zu löschen. Der Index in der Fremdschlüsselspalte ist noch vorhanden. Wenn Sie ihn löschen müssen, müssen Sie den Index löschen Separat

3. Einschränkungen-AnwendungWas sind die Konzepte von MySQL-Einschränkungen und -Indizes?

1. Einschränkungen und Indizes einer Tabelle anzeigen

#查看某个表的约束
SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称';
或
SHOW CREATE TABLE 表名;
#查看某个表的索引
SHOW INDEX FROM 表名称;

2. Primärschlüssel sind in einspaltige Primärschlüssel und zusammengesetzte Primärschlüssel unterteilt. Zusammengesetzte Primärschlüssel werden nicht empfohlen, da zusammengesetzte Primärschlüssel gegen die drei Paradigmen verstoßen Das als Primärschlüssel festgelegte Feld ist eindeutig und nicht leer. 3. Wenn mehrere Primärschlüssel vorhanden sind, kann der Primärschlüssel nicht nach dem Feld festgelegt werden (field, field)“ nach allen Feldern. 4. Im gemeinsamen Primärschlüssel ist jedes Feld, aus dem der Primärschlüssel besteht, nicht leer und kann separat verwendet werden. Wiederholen, aber nicht gleichzeitig

5. Durch das Erstellen eines Primärschlüssels wird automatisch ein entsprechender Index erstellt, und durch das Löschen des Primärschlüssels wird auch der entsprechende Index gelöscht.

3. Auto-Inkrement-Einschränkung: Auto-Inkrementierung Normalerweise werden Schlüsseleinschränkungen nur für den Primärschlüssel festgelegt, z. B. Primärschlüsseleinschränkungen, eindeutige Schlüsseleinschränkungen und Fremdschlüsseleinschränkungen

2、设置为自增的字段,从1开始自增;每次添加数据,都会在该字段最大值的基础上+1

3、使字段自增的方式:

  • 如果是空或者0,则实际插入的将是自动增长后的值。

  • a> insert into t_user(username,password) values(‘admin’,‘123456’);

  • b> insert into t_user values(null,‘root’,‘123456’); (推荐使用)

  • c> insert into t_user values(0,‘root’,‘123456’);

4、唯一键约束:unique key

create table t_user(
	id int primary key auto_increment,
    username varchar(20) unique key,
    password varchar(20) unique key
);
create table t_user(
	id int primary key auto_increment,
    username varchar(20),
    password varchar(20),
    unique key(username,password)
);
#在建表后增加唯一键约束
alter table 表名称 add 【constraint 约束名】 unique key (字段名列表);
#如果没有指定约束名,(字段名列表)中只有一个字段的,默认是该字段名,如果是多个字段的默认是字段名列表的第1个字段名。也可以通过show index from 表名;来查看
#删除唯一键约束
ALTER TABLE 表名称 DROP INDEX 唯一性约束名;
#注意:如果忘记名称,可以通过“show index from 表名称;”查看

唯一键约束的特点:

  • 1、设置唯一键约束的字段值唯一,但是可以为null

  • 2、一张表可以设置多个唯一键约束,也可以设置联合唯一键,即多个字段设置一个唯一约束,但是不能使用"unique key"写在字段后设置,必须写在所有字段后,使用"unique key(字段,字段)"

  • 3、联合唯一键要求组成唯一约束的字段可以单独重复,不能同时重复

  • 4、 MySQL会给唯一约束的列上默认创建一个唯一索引。

  • 5、删除唯一键只能通过删除对应索引的方式删除,删除时需要指定唯一键索引名

5、非空约束:not null

create table t_user(
	id int primary key auto_increment,
    username varchar(20) unique key not null,
    password varchar(20)
);
#在建表后指定某个字段非空
ALTER TABLE 表名称 MODIFY 字段名 数据类型 NOT NULL 【default 默认值】;
#如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失
#取消某个字段非空
ALTER TABLE 表名称 MODIFY 字段名 数据类型 【default 默认值】;
#如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失

非空约束的特点:

设置为非空约束的字段的值不能为null

6、默认值约束:default

create table t_user(
	id int primary key auto_increment,
    username varchar(20) unique key not null,
    password varchar(20),
    gender char not null default '男'
);

添加数据时使用默认值的方式:

不为该字段赋值或使用关键字default

  • insert into t_user(username,password) values(‘root’,‘123’);

  • insert into t_user values(null,‘admin123’,‘123’,default);

  • insert into t_user values(null,‘admin’,‘123’,null); //此方式不可以,会为该字段赋值为null

7、外键约束:foreign key

表关系:

1、一对一

2、多对一,在多的一方引用一的主键

  • student(sid,sname,age,sex,cid)–clazz(cid,cname,location)

3、一对多,在多的一方引用一的主键

  • clazz(cid,cname,location)–student(sid,sname,age,sex,cid)

4、多对多

  • user(uid,username,password)

  • order(oid,create_time,total_count,total_amount,status,user_id)

  • order_goods(id,oid,gid)

  • goods(gid,gname,price,sales,stock)

create table t_dept(
	id int primary key auto_increment,
    name varchar(20)
);
create table t_emp(
	id int primary key auto_increment,
    name varchar(20),
    age int,
    gender char,
    dept_id int,
    foreign key(dept_id) references t_dept(id) 
    #外键只能在所有字段列表后面单独指定
);
#在建表后指定外键约束
alter table 从表名称 add 【constraint 外键约束名】 foreign key (从表字段名) references 主表名(主表被参照字段名) 【on update xx】[on delete xx];
#删除外键约束
ALTER TABLE 表名称 DROP FOREIGN KEY 外键约束名;
#查看某个表的约束名
SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称';
或
SHOW CREATE TABLE 表名;
#删除外键约束不会删除对应的索引,如果需要删除索引,需要用ALTER TABLE 表名称 DROP INDEX 索引名;
#查看索引名 show index from 表名称;

(1)外键特点

  • 外键约束是保证一个或两个表之间的参照完整性,外键是构建于一个表的两个字段或是两个表的两个字段之间的参照关系。

  • 在创建外键约束时,如果不给外键约束名称,默认名不是列名,而是自动产生一个外键名(例如 student_ibfk_1;),也可以指定外键约束名。

  • 当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是列名,不是外键的约束名。

  • 删除外键时,关于外键列上的普通索引需要单独删除。

(2)要求

  • 在从表上建立外键,而且主表要先存在。

  • 一个表可以建立多个外键约束

  • 从表的外键列,在主表中引用的只能是键列(主键,唯一键,外键),推荐引用主表的主键。

  • 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样

(3)约束关系:约束是针对双方的

  • 添加了外键约束后,主表的修改和删除数据受约束

  • 添加了外键约束后,从表的添加和修改数据受约束

  • 在从表上建立外键,要求主表必须存在

  • 删除主表时,要求从表先删除,或将从表中外键引用该主表的关系先删除

(4)5个约束等级

  • Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录

  • Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null

  • No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作

  • Restrict方式:同no action, 都是立即检查外键约束

  • Set default方式(在可视化工具SQLyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别

如果没有指定等级,就相当于Restrict方式

8、检查约束:check

检查约束,mysql暂不支持

create table stu(
	sid int primary key,
	sname varchar(20),
	gender char check ('男'or'女')
);
insert into stu values(1,'张三','男');
insert into stu values(2,'李四','妖');
使用枚举类型解决如上问题:
create table stu(
	sid int primary key,
	sname varchar(20),
	gender enum ('男','女')
);

Das obige ist der detaillierte Inhalt vonWas sind die Konzepte von MySQL-Einschränkungen und -Indizes?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen