mysql之字段的修改,添加、刪除,多表關系(外鍵),單表詳細操作(增刪改)


字段的修改、添加和刪除

create table tf1(

    id int primary key auto_increment,
    x int,
    y int

);

#修改
alter table tf1 modify x char(4) default'';
alter table tf1 change y m char(4) default '';

#增加
alter table 表名 add 字段名 類型[(長度) 約束];
>:alter table student add name char(4) first;
>:alter table student add age int unsigned after name;

#刪除
alter table 表名 drop 字段名;
>: alter table student drop age;

外鍵

'''
作者(author):id,name, sex, age, mobile, author_id
作者詳情(author_detail):id, info, address
'''


# 外鍵:通常命名規范是(關聯表_關聯字段)

# 語法:foreign key(所在表的外鍵字段) references 關聯表(關聯字段)
# 在作者詳情表中寫 eg: foreign key(author_id) references author_detail(id);

#級聯關系
'''
級聯更新:on update cascade
#就是說,A和B之間用外鍵a進行了關聯,那么我對A中的外鍵a修改成b,那么B中的主鍵也會被修改,例如語句:update author_detail set id=10 where id=1;則會把author_detail表中id為1的字段設置為id為10,相對應的author表中選擇id=1當做外鍵的字段也會把外鍵author_id設置為10.


級聯刪除:on delete cascade
#比如,學生表中學生A的主鍵是id=2,成績表中有外鍵student_id=2,那么我們用語句:delete from student where id = 2,這樣在成績表里面學生A的記錄就全部刪掉了。
'''

多表關系

"""
一對一:就是一一對應的關系,比如丈夫和妻子,作者和作者詳情
一對多:就是一個和多個對應的關系,比如部門和員工,書籍和出版社
多對多:就是多個和多個之間進行對應,比如老師和班級,出版社和作者
"""

#外鍵就是 建立表與表關聯的字段, 通常 一個表的外鍵是另外一個表的主鍵(唯一鍵也可以), 例如在多對多對應的中,K1是老師A的外鍵,那么K1就可以在班級表中唯一的確定一個班級(即K1是班級的主鍵)

#外鍵值就是外鍵在表中對應的主鍵值

'''
一對一:外鍵在任何一方都可以,此時外鍵要設置成唯一鍵,例如作者和作者詳情:Q是作者A的外鍵,那Q在作者詳情表中一定是唯一確定的

一對多:外鍵必須放在多的一方,外鍵值是不唯一的,例如書和出版社:Q是書A的外鍵,Q也就出版社的主鍵,唯一確定一個出版社P,但是P可能還出版了書B,而B同樣有外鍵Q,這樣Q的外鍵值就包括了A和B了。

多對多:一定要創建第三張表(關系表),每一個外鍵值不唯一,還可以多個外鍵值聯合唯一, 例如作者和出版社,

		作者(author):id, name, age
        出版社(publish):id, name, address
        作者與出版社關系表:id, author_id, publish_id
        id		author_id		publish_id
        1			1				1
        2			1				2
        3			2				1
        4			2				2
        
從上面可以看出,關系表的外鍵A是作者表的主鍵,可以唯一確認一個作者,外鍵B是出版社表的主鍵,可以唯一確認一個出版社,這樣A和B的組合就可以是聯合唯一了,即在第三張表中唯一確認。
'''


單表詳細操作:增刪改

一對一:無級聯關系

# 作者詳情(author_detail): id,info,address
create table author_detail(
	id int primary key auto_increment,
    info varchar(256),
    address varchar(256)
);

# 作者表id,name,sex,age,mobile, detail_id
create table author(
	id int primary key auto_increment,
    name varchar(64) not null,
    mobile char(11) unique not null,
    sex enum('男', '女') default '男',
    age int default 0,
    detail_id int unique not null,
    foreign key(detail_id) references author_detail(id)
);

# 必須先創建被關聯表數據,有關聯表外鍵關聯的記錄后,關聯表才可以創建數據
mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);

# 修改關聯表 author
mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他數據關聯的數據,就可以修改
# 刪除關聯表 author
mysql>: delete from author where detail_id=3;  # 直接刪除

# 修改被關聯表 author_detail
mysql>: update author_detail set id=10 where id=1;  # 無法修改
# 刪除被關聯表 author_detail
mysql>: delete from author_detail where id=1;  # 無法刪除

# 沒有級聯關系下:
# 增加:先增加被關聯表記錄,再增加關聯表記錄
# 刪除:先刪除關聯表記錄,再刪除被關聯表記錄
# 更新:關聯與被關聯表都無法完成 關聯的外鍵和主鍵 數據更新 - (如果被關聯表記錄沒有被綁定,可以修改)

一對一:有級聯關系

mysql>: drop table author;
mysql>: drop table author_detail;


# 作者詳情(author_detail): id,info,address
create table author_detail(
	id int primary key auto_increment,
    info varchar(256),
    address varchar(256)
);

# 作者表id,name,sex,age,mobile, detail_id
create table author(
	id int primary key auto_increment,
    name varchar(64) not null,
    mobile char(11) unique not null,
    sex enum('男', '女') default '男',
    age int default 0,
    detail_id int unique not null,
    foreign key(detail_id) references author_detail(id)
    on update cascade 
    on delete cascade
);



# 必須先創建被關聯表數據,有關聯表外鍵關聯的記錄后,關聯表才可以創建數據
mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);  # 錯誤
mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);

# 修改關聯表 author
mysql>: update author set detail_id=3 where detail_id=2;  # 失敗,3詳情不存在(此處是關聯表,即把第id為2的字段修改為id=3的)
mysql>: update author set detail_id=1 where detail_id=2;  # 失敗,1詳情已被關聯
mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他數據關聯的數據,就可以修改
# 刪除關聯表 author
mysql>: delete from author where detail_id=3;  # 直接刪除

# 修改被關聯表 author_detail
mysql>: update author_detail set id=10 where id=1;  # 級聯修改,同步關系關聯表外鍵

# 刪除被關聯表 author_detail
mysql>: delete from author where detail_id=10;  # 可以刪除對被關聯表無影響
mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 10);
mysql>: delete from author_detail where id=10;  # 可以刪除,將關聯表的記錄級聯刪除掉

一對多

# 一對多:外鍵必須放在多的一方,此時外鍵值不唯一

# 出版社(publish): id,name,address,phone
create table publish(
	id int primary key auto_increment,
    name varchar(64),
    address varchar(256),
    phone char(20)
);

# 書(book):id,name,price,publish_id, author_id
create table book(
	id int primary key auto_increment,
    name varchar(64) not null,
    price decimal(5, 2) default 0,
    publish_id int,  # 一對多的外鍵不能設置唯一
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade
);

# 增:先增加被關聯表(publish)的數據,再增加關聯表(book)的數據
mysql>: insert into publish(name, address, phone) values
('人民出版社', '北京', '010-110'),
('西交大出版社', '西安', '010-119'),
('老男孩出版社', '上海', '010-120');

mysql>: insert into book(name, price, publish_id) values
('西游記', 6.66, 1),
('東游記', 8.66, 1),
('python從入門到入土', 2.66, 2),
('輪程序員修養之道', 3.66, 3),
('好好活着', 88.88, 3);
# 沒有被關聯的字段,插入依舊錯誤
mysql>: insert into book(name, price, publish_id) values ('打臉之道', 0.3, 4);  # 失敗


# 更新:直接更新被關聯表的(publish) 主鍵,關聯表(book) 外鍵 會級聯更新
mysql>: update publish set id=10 where id=1;
# 更新:直接更新關聯表的(book) 外鍵,修改的值對應被關聯表(publish) 主鍵 如果存在,可以更新成功,反之失敗
mysql>: update book set publish_id=2 where id=4;  # 成功
mysql>: update book set publish_id=1 where id=4;  # 失敗


# 刪:
#	刪被關聯表,關聯表會被級聯刪除
mysql>: delete from publish where id = 2;

#	刪關聯表,被關聯表不會發生變化
mysql>: delete from book where publish_id = 3;
# 假設:書與作者也是 一對多 關系,一個作者可以出版多本書
create table book(
	id int primary key auto_increment,
    name varchar(64) not null,
    price decimal(5, 2) default 0,
    publish_id int,  # 一對多的外鍵不能設置唯一
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade
    
    # 建立與作者 一對多 的外鍵關聯
    author_id int,  
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade
);

多對多

# 多對多:一定要創建第三張表(關系表),每一個外鍵值不唯一,看可以多個外鍵建立聯合唯一

mysql>: drop table author;
mysql>: drop table author_detail;
mysql>: drop table book;
mysql>: drop table publish;

# 作者(author):id, name, age
create table author(
	id int primary key auto_increment,
    name varchar(64),
    age int unsigned default 0
);

# 出版社(publish):id, name, address
create table publish(
	id int primary key auto_increment,
    name varchar(64),
    address varchar(256)
);

# 作者與出版社關系表:id, author_id, publish_id
create table author_publish(
	id int primary key auto_increment,
    # 關系表一定有多個外鍵,關聯着多張表
    # 關聯作者表
    author_id int,
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade,
    # 關聯出版社表
    publish_id int,
    foreign key(publish_id) references publish(id)
    on update cascade
    on delete cascade,
    # 建立兩個字段的聯合唯一
    unique(author_id, publish_id)
);

# 注:關系表 關聯着 作者 和 出版社 兩張表,在表結構上 作者 與 出版社 兩表鍵沒有任何關系


# 增:兩張被關聯表,沒有前后關系,但關系表必須在兩個表都提供數據后才能進行 關系匹配
mysql>: insert into author(name, age) values('ruakei', 67),('engo', 76),('Lxx', 3);
mysql>: insert into publish(name, address) values('老男孩出版社', '上海'),('小女孩出版社', '北京');

# 操作關系表:
mysql>: insert into author_publish(author_id, publish_id) values(1,1),(1,2),(2,1),(2,2),(3,1);

# 關系表操作:增、刪、改,只要兩張被關系表有提供對應的操作數據,都可以操作成功,且對兩張被關系表沒有影響


# 操作兩張被關系表:
#		增:不會影響關系表
mysql>: insert into publish(name, address) values('西交大出版社', '西安');
#		改:關系表都會級聯更新
mysql>: update publish set id=10 where id=1;
#		刪:關系表都會級聯刪除
mysql>: delete from author where name='ruakei';


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM