Fassen Sie die Tabellenstruktur der MySQL-Wissenspunkte ausführlich zusammen und erläutern Sie sie
WBOY
Freigeben: 2022-03-04 17:12:12
nach vorne
2418 Leute haben es durchsucht
Dieser Artikel vermittelt Ihnen relevantes Wissen über MySQL, das hauptsächlich die Tabellenstruktur einschließlich Einschränkungen und damit verbundene Probleme beim Ändern der Tabellenstruktur vorstellt. Ich hoffe, dass es für alle hilfreich ist.
Die Funktion besteht darin, die Zuweisung von Werten zu Feldern einzuschränken
Einschränkungen anzeigen
MySQL& gt; desc Bibliotheksname.Tabellenname ;
rrree
//Wie im Bild gezeigt, ist die Bedeutung jeder Spalte |. Standardwert | Einschränkungen dürfen leer sein (NULL), sodass der Wert bei der Zuweisung hier leer sein kann. Bei Null wird die Groß-/Kleinschreibung nicht beachtet Feld ist NULL, was bedeutet, dass, wenn das dritte Feld nicht angegeben ist. Beim Zuweisen eines Werts wird die Tabelle mit dem Standardwert gefüllt, d. h. NULL wird standardmäßig ausgefüllt, wie in der Abbildung unten gezeigt
Legen Sie die Einschränkungen fest
null //Leer zulassen (Standardeinstellung)
not null //Null ist nicht zulässig
key
mysql> desc db1.t9;
Nach dem Login kopieren
// Erstellen Sie eine Tabelle db2.t1 Der Typ Das Feld „Name“ hat eine feste Länge. Die Einschränkung besteht darin, dass es nicht leer sein darf. Der Anzeigeeffekt ist wie in der Abbildung unten dargestellt Die Einschränkung lautet: Negative Zahlen (ohne Vorzeichen) sind nicht zulässig und der Standardwert ist auf 19 festgelegt. Beachten Sie, dass die Standardwerteinstellung hier den Bereich des Typs tinyint nicht überschreiten darf, dh die Standardwerteinstellung darf 255 nicht überschreiten. Der Typ des Geschlechtsfelds ist eine Aufzählung und die Einschränkung besteht darin, dass es nicht leer sein darf und der Standardwert auf mysql> gesetzt ist
mysql> insert into t9 values (null,null,null);
Nach dem Login kopieren
// Weisen Sie nur dem Namensfeld Werte zu, und den übrigen Feldern werden standardmäßig Werte zugewiesen
mysql> select * from db1.t9;
Nach dem Login kopieren
mysql> insert into db1.t9(name,sex) values("lucy","girl");
mysql> select * from db1.t9;
Nach dem Login kopieren
mysql> create database db2;
mysql> create table db2.t1(
-> name char(10) not null default "",
-> age tinyint unsigned default 19,
-> sex enum("m","w") not null default "m"
-> );
Nach dem Login kopieren
Zusammenfassung
Einschränkungen
Typ
Null (ob null zulässig ist)
Standardmäßig null zulassen
Nicht null.
Primär Schlüssel Primärschlüssel
„Fremdschlüssel Fremdschlüssel“ null, wenn nicht definiert
mysql> alter table db2.t1 modify age tinyint unsigned default 19 after class; //除了对字段age的位置进行了修改,其余不修改的地方如:类型(宽度)、约束条件进行原样抄写
mysql> desc db2.t1;
将字段name的类型变为varchar(15)
mysql> alter table db2.t1 modify name varchar(15) not null default "";
mysql> desc db2.t1;
Nach dem Login kopieren
修改字段名
基本用法
—— 也可以用来修改字段类型
mysql> alter table 库名.表名 change 源字段名 新字段名 类型(宽度) 约束条件;
注:也可以用来修改类型和约束条件,只需要写上新的类型和新的约束条件即可
mysql> desc db2.t1;
将字段名email修改为mail
mysql> alter table db2.t1 change email mail varchar(50);
mysql> desc db2.t1;
将字段名mail修改为email,并修改约束条件
mysql> alter table db2.t1 change mail email varchar(50) not null default "njw@163.com"; //出现错误,因为源数据中,mail字段中的值为NULL,如果将约束条件修改为not null,那么就与源数据发生冲突,所以修改失败
ERROR 1138 (22004): Invalid use of NULL value
mysql> alter table db2.t1 change mail email varchar(50) default "njw@163.com";
mysql> desc db2.t1;
Nach dem Login kopieren
删除字段
基本用法
mysql> alter table 库名.表名 drop 字段名;
mysql> alter table db2.t1 drop email; //删除库db2中表t1的字段email
mysql> desc db2.t1; //没有字段email,已被删除
Nach dem Login kopieren
mysql> select * from db2.t1; //字段email及其数据已被删除
修改表名
基本用法
mysql> alter table 库名.表名 rename 新表名;
库名.新表名;
mysql> use db2;
mysql> show tables;
mysql> alter table db2.t1 rename stuinfo; //将表名修改为stuinfo
Das obige ist der detaillierte Inhalt vonFassen Sie die Tabellenstruktur der MySQL-Wissenspunkte ausführlich zusammen und erläutern Sie sie. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn