Artikel ini membawakan anda pengetahuan yang berkaitan tentang mysql Ia terutamanya memperkenalkan struktur jadual termasuk kekangan dan isu berkaitan pengubahsuaian struktur jadual.
Pembelajaran yang disyorkan: tutorial mysql
Apakah sekatan ? Berikan nilai pada medan
mysql> desc nama.table name;
mysql> desc db1.t9;
//Seperti yang ditunjukkan dalam gambar, maksud setiap lajur ialah: nama medan | nilai utama kosong | 🎜>
//Seperti yang ditunjukkan dalam rajah di atas, kekangan dibenarkan kosong (NULL), jadi nilai boleh kosong apabila menetapkan di sini tidak sensitif huruf besar/kecilmysql> insert into t9 values (null,null,null);
mysql> select * from db1.t9;
mysql> insert into db1.t9(name,sex) values("lucy","girl"); mysql> select * from db1.t9;
Tetapkan kekangan
<. 🎜>null 🎜>bukan batal //Null (kosong) tidak dibenarkanmysql> medan nama, dan medan selebihnya diberikan nilai lalai
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" -> );
Ringkasan
mysql> insert into db2.t1(name) values("bob"); Salin selepas log masuk | Jenis mysql> select * from db2.t1; Salin selepas log masuk | ||||||||||||||||||||||
Nol (sama ada null dibenarkan) | Lalai membenarkan nullmysql> insert into db2.t1 values("lucy","21","w"); //给字段赋值,就不会以默认值赋值了 mysql> select * from db2.t1; Salin selepas log masuk | ||||||||||||||||||||||
Bukan batal | |||||||||||||||||||||||
Kunci (nilai kunci )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; Salin selepas log masuk | Indeks indeks biasa | ||||||||||||||||||||||
Indeks unik unik< /td> | |||||||||||||||||||||||
kunci utama kunci utama
| |||||||||||||||||||||||
<🎜>kunci asing kunci asing<🎜> | |||||||||||||||||||||||
< 🎜>teks penuh indeks teks penuh< 🎜> | |||||||||||||||||||||||
<🎜>Lalai (nilai lalai: jangan berikan nilai pada medan dan gunakan penetapan nilai lalai) <🎜>< /td> | <🎜>Apabila lalai tidak ditakrifkan Ia adalah batal<🎜> | ||||||||||||||||||||||
<🎜>Ia adalah lalai apabila ditakrifkan (untuk memadankan jenis medan)<🎜> | |||||||||||||||||||||||
<🎜>Tambahan (tetapan tambahan: tiada tetapan tambahan secara lalai)<🎜> | < td>
用法
mysql> alter table 库名.表名 执行动作;
执行动作
add 添加字段
modify 修改字段类型
change 修改字段名
drop 删除字段
rename 修改表名
用法
—— 新字段默认添加在字段末尾
mysql> alter table 库名.表名 add 字段名 类型(宽度) 约束条件;
add 字段名 类型 [约束条件] after 字段名;
add 字段名 类型 [约束条件] first;
不指定位置添加字段
mysql> alter table db2.t1 add email varchar(50); //不指定添加字段的位置,默认就在末尾 mysql> desc db2.t1;
在某一字段后面添加字段
mysql> alter table db2.t1 add hobby set("eat","drink","play","happy") not null default "eat,drink" after age; //指定添加位置在字段age之后,条件设置不允许为空,并设置默认值为eat,drink mysql> desc db2.t1;
mysql> select * from db2.t1; //查看表内容,发现hobby字段自动添加了默认值
将字段添加到最前面
mysql> alter table db2.t1 add class char(7) default "B180601" first; //将字段class添加到最前面 mysql> desc db2.t1;
mysql> select * from db2.t1; //class字段自动添加默认值
基本用法
—— 修改的字段类型不能与已存储的数据冲突
mysql> alter table 库名.表名 modify 字段名 类型(宽度) 约束条件;
modify 字段名 类型 [约束条件] after 字段名;
modify 字段名 类型 [约束条件] first;
注:
如果表中这个字段类型下面的字段已经有值了,那么修改的类型与约束不能与字段里面已经存储的数据发生冲突,如果发生冲突则不允许修改。比如,有一个字段name,里面存储了一个数据为bob,那么把字段的类型(宽度)改成char(1),则会修改失败,因为bob的宽度为3,如果将字段的类型(宽度)改为char(1),则源数据bob就存不下了,由于已存储的数据优先,所以就不能进行修改;
修改字段的类型时要注意,不修改的部分要原样进行抄写,如果不修改的部分不原样抄写,那就相当于对其进行还原即使用默认配置。比如有一个字段name,他的类型是char(10),约束条件是不允许为空,默认值是"",现在要将其类型宽度改为char(20),其余没修改的部分没有在命令中进行原样抄写,那么输出结果该字段的约束条件会变为默认情况,即允许为空,默认值为NULL。改变字段位置的时候也一样。
mysql> desc db2.t1;
将字段age的位置修改到字段class的后面
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;
基本用法
—— 也可以用来修改字段类型
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;
基本用法
mysql> alter table 库名.表名 drop 字段名;
mysql> alter table db2.t1 drop email; //删除库db2中表t1的字段email mysql> desc db2.t1; //没有字段email,已被删除
mysql> select * from db2.t1; //字段email及其数据已被删除
基本用法
mysql> alter table 库名.表名 rename 新表名;
库名.新表名;
mysql> use db2;
mysql> show tables;
mysql> alter table db2.t1 rename stuinfo; //将表名修改为stuinfo
mysql> show tables;
mysql> select * from stuinfo;
推荐学习:mysql视频教程
Atas ialah kandungan terperinci Ringkaskan dan terangkan struktur jadual mata pengetahuan MySQL secara terperinci. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!