首先要準(zhǔn)備三個(gè)表Student學(xué)生表、Course課程表、SC選課表
學(xué)生表 | 學(xué)號(hào) | 姓名 | 年齡 | 性別 | 院系 |
Student | Sno | Sname | Sage | Ssex | Sdept |
課程表 | 課程號(hào) | 課程名 | 先行課 | 學(xué)分 |
Course | Cno | Cname | Cpno | Ccredit |
選課表 | 學(xué)號(hào) | 課程號(hào) | 成績(jī) |
SC | Sno | Cno | Grade |
sql語句 創(chuàng)建表
-- 刪除表
DROP TABLE IF EXISTS Student;
-- 創(chuàng)建表
CREATE TABLE Student(
Sno CHAR(9) PRIMARY KEY,-- 學(xué)號(hào) 主鍵
Sname VARCHAR(20) NOT NULL,-- 姓名 非空且唯一
Sage INT NOT NULL,-- 年齡
Ssex VARCHAR(5) NOT NULL,-- 性別
Sdept VARCHAR(10) NOT NULL -- 所在系
)charset=utf8;
-- 刪除表
DROP TABLE IF EXISTS Course;
-- 創(chuàng)建表
CREATE TABLE Course(
Cno CHAR(5) PRIMARY KEY,-- 課程號(hào) 主鍵
Cname VARCHAR(20) NOT NULL ,-- 課程名 非空
Cpno VARCHAR(20) NOT NULL,-- 先行課
Ccredit Double(5,2) NOT NULL-- 學(xué)分
)charset=utf8;
-- 刪除表
DROP TABLE IF EXISTS SC;
-- 創(chuàng)建表
CREATE TABLE SC(
Sno CHAR(9),-- 學(xué)號(hào) 主鍵
Cno CHAR(5),-- 課程號(hào) 主鍵
Grade INT NOT NULL, -- 成績(jī)
foreign key(Sno) references Student(Sno),
foreign key(Cno) references Course(Cno)
)charset=utf8;
注意創(chuàng)建表的時(shí)候要注意它的字段名,類型,長(zhǎng)度,約束條件,取值范圍要合適,大小寫符號(hào)要正確,中文逗號(hào),分號(hào)和英文的要注意區(qū)分,sql語句有時(shí)運(yùn)行不起來,可能就在某個(gè)標(biāo)點(diǎn)符號(hào)寫漏或者寫錯(cuò)
這里Sno 和 Cno 分別是學(xué)生表和課程表的主鍵,但同時(shí)又是SC的外鍵,這里要寫外鍵約束
插入數(shù)據(jù)
INSERT INTO Student
(Sno,Sname,Sage,Ssex,Sdept) VALUES
('20211127','殷郊',22,'男','數(shù)學(xué)系'),
('20211128','姬發(fā)',20,'男','農(nóng)業(yè)系'),
('20211129','蘇妲己',18,'女','外語系'),
('20211130','崇應(yīng)彪',23,'男','體育系')
INSERT INTO Course
(Cno,Cname,Cpno,Ccredit) VALUES
('1001','數(shù)據(jù)庫(kù)原理及應(yīng)用','數(shù)據(jù)結(jié)構(gòu)',2),
('2002','LINUX操作系統(tǒng)與程序設(shè)計(jì)','操作系統(tǒng)',4),
('3003','離散數(shù)學(xué)','高等數(shù)學(xué)',2),
('4004','Java程序設(shè)計(jì)語言','c語言和c++語言',2),
('5005','網(wǎng)絡(luò)安全','計(jì)算機(jī)網(wǎng)絡(luò)',4)
INSERT INTO SC
(Sno,cno,Grade) VALUES
('20211127','1001',98),
('20211127','2002',96),
('20211127','3003',95),
('20211127','4004',90),
('20211127','5005',93),
('20211128','1001',98),
('20211128','2002',96),
('20211128','3003',95),
('20211128','4004',90),
('20211128','5005',93),
('20211129','1001',98),
('20211129','2002',96),
('20211129','3003',95),
('20211129','4004',90),
('20211129','5005',93),
('20211130','1001',98),
('20211130','2002',96),
('20211130','3003',95),
('20211130','4004',90),
('20211130','5005',93)
查詢數(shù)據(jù)表
-- 查詢表所有
select * from Student;
select * from Course;
select * from SC;
結(jié)果
?
?
?還可以多表查詢
-- 多表查詢,
-- 查詢表 Student和SC
SELECT SC.Sno AS 學(xué)生學(xué)號(hào) ,Student.Sname AS 學(xué)生姓名,Student.Ssex AS 學(xué)生性別 Student.Sdept AS 學(xué)生院系,SC.Cno AS 選擇課程號(hào),SC.Grade AS 課程成績(jī)
FROM SC,Student
WHERE SC.Sno=Student.Sno;
-- 查詢表 course 和 SC
SELECT SC.Sno AS 學(xué)生學(xué)號(hào) ,SC.Cno AS 選擇課程號(hào),Course.Cname AS 學(xué)生課程名, Course.cpno AS 學(xué)生先行課, Course.Ccredit AS 課程學(xué)分, SC.Grade AS 課程成績(jī)
FROM SC,Course
WHERE SC.Cno=Course.Cno;
-- 查詢表 course 和 SC 和 Student
SELECT SC.Sno AS 學(xué)生學(xué)號(hào) ,Student.Sname AS 學(xué)生姓名,Student.Ssex AS 學(xué)生性別, Student.Sdept AS 學(xué)生院系,
SC.Cno AS 選擇課程號(hào),Course.Cname AS 學(xué)生課程名, Course.cpno AS 學(xué)生先行課, Course.Ccredit AS 課程學(xué)分,SC.Grade AS 課程成績(jī)
FROM SC,Student,Course
WHERE SC.Sno=Student.Sno AND SC.Cno=Course.Cno AND SC.Sno= 20211127;
這里,感興趣的自己去試一試吧,
修改數(shù)據(jù)表(單個(gè)示例)
?
-- 修改語句 單個(gè)示例
update Student set Sname='姜子牙' where Sno='20211127';
-- 刪除語句,單個(gè)示例
-- 這里刪除不了是因?yàn)橥怄I約束的問題
delete from Student where Sno='20211127';
?
最后提醒
如果最后操作運(yùn)行時(shí)出錯(cuò),可能是SC表設(shè)置了外鍵約束的問題,
?它可能報(bào)這種錯(cuò)誤,原因是想要?jiǎng)h除的數(shù)據(jù)和表與其他的數(shù)據(jù)或表存在主外鍵關(guān)系,MYSQL規(guī)定文章來源:http://www.zghlxwxcb.cn/news/detail-721125.html
為了維護(hù)表結(jié)構(gòu)的穩(wěn)定,禁止執(zhí)行該操作,即外鍵約束失敗,解決方法,將帶有外鍵約束的表刪掉,,然后重新執(zhí)行其他數(shù)據(jù)表即可,亦或者解除外鍵關(guān)聯(lián),然后執(zhí)行增刪改查操作,然后重新建立外鍵關(guān)聯(lián)文章來源地址http://www.zghlxwxcb.cn/news/detail-721125.html
到了這里,關(guān)于mysql,用sql語句,建立學(xué)生-課程數(shù)據(jù)庫(kù)基本表的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!