


Ringkaskan dan terangkan struktur jadual mata pengetahuan MySQL secara terperinci
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
Syarat kekangan
Apakah sekatan ? Berikan nilai pada medan
Lihat kekangan
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
- kunci Lalai ialah NULL
- tambahan
- //Buat jadual db2.t1, jenis medan nama ialah Aksara panjang tetap, kekangan tidak dibenarkan kosong, nilai lalai ialah 0 aksara , kesan paparan adalah seperti yang ditunjukkan dalam rajah di bawah; jenis medan umur ialah tinyint integer kecil, kekangan tidak dibenarkan menjadi nombor negatif (tidak bertanda), nilai lalai ditetapkan ialah 19. Perhatikan bahawa lalai tetapan nilai di sini tidak boleh melebihi julat jenis tinyint, iaitu tetapan nilai lalai tidak boleh melebihi 255 jenis medan jantina ialah penghitungan, enum ialah pemilihan radio, dan kekangannya ialah ia tidak dibenarkan; kosongkan. Tetapan nilai lalai ialah m;
mysql> 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");Kekangan |
Jenis mysql> select * from db2.t1; |
||||||||||||||||||||||
Nol (sama ada null dibenarkan) |
Lalai membenarkan nullmysql> insert into db2.t1 values("lucy","21","w"); //给字段赋值,就不会以默认值赋值了 mysql> select * from db2.t1; | ||||||||||||||||||||||
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; |
Indeks indeks biasa |
||||||||||||||||||||||
Indeks unik unik | |||||||||||||||||||||||
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) | Apabila lalai tidak ditakrifkan Ia adalah batal | ||||||||||||||||||||||
Ia adalah lalai apabila ditakrifkan (untuk memadankan jenis medan) | |||||||||||||||||||||||
Tambahan (tetapan tambahan: tiada tetapan tambahan secara lalai) |
修改表结构
语法结构
用法
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!

Atribut asid termasuk atom, konsistensi, pengasingan dan ketahanan, dan merupakan asas reka bentuk pangkalan data. 1. Atomicity memastikan bahawa urus niaga sama ada berjaya atau gagal sepenuhnya. 2. Konsistensi memastikan pangkalan data tetap konsisten sebelum dan selepas transaksi. 3. Pengasingan memastikan bahawa urus niaga tidak mengganggu satu sama lain. 4. Kegigihan memastikan data disimpan secara kekal selepas penyerahan transaksi.

MySQL bukan sahaja sistem pengurusan pangkalan data (DBMS) tetapi juga berkait rapat dengan bahasa pengaturcaraan. 1) Sebagai DBMS, MySQL digunakan untuk menyimpan, menyusun dan mengambil data, dan mengoptimumkan indeks dapat meningkatkan prestasi pertanyaan. 2) Menggabungkan SQL dengan bahasa pengaturcaraan, tertanam dalam Python, menggunakan alat ORM seperti SQLalChemy dapat memudahkan operasi. 3) Pengoptimuman prestasi termasuk pengindeksan, pertanyaan, caching, perpustakaan dan bahagian meja dan pengurusan transaksi.

MySQL menggunakan arahan SQL untuk menguruskan data. 1. Perintah asas termasuk pilih, masukkan, kemas kini dan padam. 2. Penggunaan lanjutan melibatkan fungsi gabungan, subquery dan agregat. 3. Kesilapan umum termasuk isu sintaks, logik dan prestasi. 4. Petua Pengoptimuman termasuk menggunakan indeks, mengelakkan Pilih* dan menggunakan had.

MySQL adalah sistem pengurusan pangkalan data relasi yang sesuai untuk menyimpan dan menguruskan data. Kelebihannya termasuk pertanyaan berprestasi tinggi, pemprosesan transaksi fleksibel dan jenis data yang kaya. Dalam aplikasi praktikal, MySQL sering digunakan dalam platform e-dagang, rangkaian sosial dan sistem pengurusan kandungan, tetapi perhatian harus dibayar kepada pengoptimuman prestasi, keselamatan data dan skalabilitas.

Hubungan antara SQL dan MySQL adalah hubungan antara bahasa standard dan pelaksanaan khusus. 1. SQL adalah bahasa standard yang digunakan untuk mengurus dan mengendalikan pangkalan data relasi, membolehkan penambahan data, penghapusan, pengubahsuaian dan pertanyaan. 2.MYSQL adalah sistem pengurusan pangkalan data tertentu yang menggunakan SQL sebagai bahasa pengendaliannya dan menyediakan penyimpanan dan pengurusan data yang cekap.

InnoDB menggunakan redolog dan undologs untuk memastikan konsistensi dan kebolehpercayaan data. 1. Pengubahsuaian halaman data rekod untuk memastikan pemulihan kemalangan dan kegigihan transaksi. 2.UNDOLOGS merekodkan nilai data asal dan menyokong penggantian transaksi dan MVCC.

Metrik utama untuk menjelaskan arahan termasuk jenis, kunci, baris, dan tambahan. 1) Jenis mencerminkan jenis akses pertanyaan. Semakin tinggi nilai, semakin tinggi kecekapan, seperti const adalah lebih baik daripada semua. 2) Kunci memaparkan indeks yang digunakan, dan null menunjukkan tiada indeks. 3) Baris menganggarkan bilangan baris yang diimbas, yang mempengaruhi prestasi pertanyaan. 4) Tambahan memberikan maklumat tambahan, seperti menggunakanFilesort meminta bahawa ia perlu dioptimumkan.

MenggunakanTemary menunjukkan bahawa keperluan untuk membuat jadual sementara dalam pertanyaan MySQL, yang biasanya dijumpai di Orderby menggunakan lajur yang berbeza, GroupBy, atau tidak diindeks. Anda boleh mengelakkan berlakunya indeks dan menulis semula pertanyaan dan meningkatkan prestasi pertanyaan. Khususnya, apabila menggunakan pembelian muncul dalam menjelaskan output, ini bermakna MySQL perlu membuat jadual sementara untuk mengendalikan pertanyaan. Ini biasanya berlaku apabila: 1) deduplikasi atau pengelompokan apabila menggunakan yang berbeza atau kumpulan; 2) Susun apabila Orderby mengandungi lajur bukan indeks; 3) Gunakan subquery kompleks atau menyertai operasi. Kaedah Pengoptimuman termasuk: 1) Orderby dan GroupB


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa