Cet article vous apporte des connaissances pertinentes sur mysql, qui présente principalement la structure des tables, y compris les contraintes et les problèmes liés à la modification de la structure des tables. J'espère qu'il sera utile à tout le monde.
La fonction est de limiter la façon d'attribuer des valeurs aux champs
Afficher les contraintes
mysql> nom.nom de la table ;
mysql> desc db1.t9;
Copier après la connexion
//Comme le montre l'image, la signification de chaque colonne est : nom du champ | type de clé | valeur par défaut | paramètres supplémentaires
mysql> insert into t9 values (null,null,null);
Copier après la connexion
//Comme le montre l'image ci-dessus , les contraintes peuvent être vides (NULL ), donc la valeur peut être vide lors de l'attribution ici, null n'est pas sensible à la casse
mysql> select * from db1.t9;
Copier après la connexion
mysql> insert into db1.t9(name,sex) values("lucy","girl");
mysql> select * from db1.t9;
Copier après la connexion
//Dans les contraintes de la table t9, la valeur par défaut du troisième le champ est NULL, ce qui signifie que lorsque le troisième champ n'est pas donné Lors de l'attribution d'une valeur, le tableau sera rempli avec la valeur par défaut, c'est-à-dire que NULL est renseigné par défaut comme le montre la figure ci-dessous
Définir les contraintes
null //Autoriser à être vide (paramètre par défaut)
not null //Null n'est pas autorisé
key
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"
-> );
Copier après la connexion
// Créer une table db2.t1 Le type. du champ de nom est un caractère de longueur fixe. La contrainte est qu'il ne peut pas être vide. La valeur par défaut est de 0 caractère. L'effet d'affichage est comme indiqué dans la figure ci-dessous. . La contrainte est Les nombres négatifs (non signés) ne sont pas autorisés et la valeur par défaut est définie sur 19. Notez que la valeur par défaut ici ne doit pas dépasser la plage du type tinyint, c'est-à-dire que la valeur par défaut ne peut pas dépasser 255 ; le type du champ sex est une énumération et enum est une sélection radio, la contrainte est qu'il ne peut pas être vide et la valeur par défaut est définie sur m;
mysql> insert into db2.t1(name) values("bob");
Copier après la connexion
//Attribuez uniquement des valeurs au champ de nom, et les champs restants se voient attribuer des valeurs par défaut
mysql> select * from db2.t1;
Copier après la connexion
mysql> insert into db2.t1 values("lucy","21","w"); //给字段赋值,就不会以默认值赋值了
mysql> select * from db2.t1;
Copier après la connexion
mysql> insert into db2.t1 values(null,null,null);
//错误提示,name字段不允许为空;name和sex字段都不能为空
ERROR 1048 (23000): Column 'name' cannot be null
mysql> insert into db2.t1 values("null",null,"w");
//"null"的意思不再是空,仅仅是字符null,没有空的含义了,所以可以给字段赋值
mysql> insert into db2.t1 values("",null,"w");
//""为0个字符,和空不一样,也可以给字段赋值
mysql> select * from db2.t1;
Copier après la connexion
Résumé
Contraintes
"Type" Clé (valeur clé)
index normal index
index unique unique
Clé primaire clé primaire
clé étrangère clé étrangère
index texte intégral fulltext
Default (valeur par défaut : ne pas attribuer de valeur au champ Utiliser l'affectation de valeur par défaut)
La valeur par défaut est nulle lorsqu'elle n'est pas définie
Il est par défaut lorsqu'il est défini (pour correspondre au type de champ)
Extra (paramètres supplémentaires : il n'y a pas de paramètres supplémentaires par défaut)
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;
Copier après la connexion
修改字段名
基本用法
—— 也可以用来修改字段类型
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;
Copier après la connexion
删除字段
基本用法
mysql> alter table 库名.表名 drop 字段名;
mysql> alter table db2.t1 drop email; //删除库db2中表t1的字段email
mysql> desc db2.t1; //没有字段email,已被删除
Copier après la connexion
mysql> select * from db2.t1; //字段email及其数据已被删除
修改表名
基本用法
mysql> alter table 库名.表名 rename 新表名;
库名.新表名;
mysql> use db2;
mysql> show tables;
mysql> alter table db2.t1 rename stuinfo; //将表名修改为stuinfo
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn