日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql数据库关联练习_mysql数据库建立数据表的练习(附代码)

發布時間:2025/3/11 数据库 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql数据库关联练习_mysql数据库建立数据表的练习(附代码) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

數據庫操作和學習并不難,難的是如何在各種實際運用情況下編寫SQL語句的實現。這個過程,需要大量的練習,那么從這里開始,我們來講解實現。

任務概述

具體關系數據庫如下:

數據庫名:教師數據庫

教師表(編號 char(6),姓名,性別,民族,職稱,身份證號)

課程表(課號 char(6),名稱)

任課表(ID,教師編號,課號,課時數)

用SQL語言實現下列功能的sql語句代碼:

(1).創建上述三表的建庫、建表代碼;

要求使用:主鍵(教師表.編號,課程表.課號)、外鍵(任課表.教師編號,任課表.課號)、默認(民族)、非空(民族,姓名)、唯一(身份證號)、檢查(性別(男、女)、課時數(0-200)),自動編號(ID)

(2).將下列課程信息添加到課程表的代碼

課號??????課程名稱

100001????SQL Server數據庫

100002????數據結構

100003????VB程序設計

修改??課號為100003的課程名稱:Visual Basic程序設計

刪除??課號為100003的課程信息

(3).寫出讀取(教師編號,姓名,課號,課程名稱,課時數)的代碼;

(4).?讀取所有代'SQL Server數據庫'這門課程的老師姓名的檢索代碼;

(5).?寫出創建[統計課時數]的代碼,要求加上別名:輸出最大課時數、最低課時數、平均課時的執行代碼;

(6).寫出創建:計算某教師代課總課時,代碼。

執行:計算“郭老師”的總課時。

(7).檢索有一門或一門以上課程課時數大于90的所有教師的信息,包括編號、姓名。

(8).建一個規則,并將其綁定到教師表的職稱列上,規定取值為('教授','副教授','講師', '助教')之一。

示例源碼如下

#(1)

drop database if exists TeacherDB;

create database TeacherDB default character set utf8 collate

utf8_bin;

use TeacherDB;

create table Teacher(

tid char(6) primary key,

tName varchar(16) not null,

tSex char(2) check(tSex='男' or tSex='女'),

tNation varchar(16) default '漢' not null,

tLevel varchar(16),

tCode varchar(18),

unique(tCode)

);

create table Course(

cid char(6) primary key,

cName varchar(64)

);

create table TeacherCourses(

ID int primary key auto_increment,

tid char(6),

cid char(6),

cCount float check(cCount>=0 and cCount<=200),

foreign key(tid) references Teacher(tid),

foreign key(cid) references Course(cid)

);

insert into Teacher values('t001','郭老師','男',default,'助教','123');

insert into Teacher values('t002','何老師','男',default,'副教授','456');

insert into Teacher values('t003','蔣老師','女','苗','講師','789');

#(2)

insert into Course values('100001','SQL Server數據庫');

insert into Course values('100002','數據結構');

insert into Course values('100003','VB程序設計');

insert into TeacherCourses values(null,'t001','100001',80);

insert into TeacherCourses values(null,'t002','100002',90);

insert into TeacherCourses values(null,'t002','100003',70);

insert into TeacherCourses values(null,'t001','100002',100);

insert into TeacherCourses values(null,'t001','100002',90);

#(3)

select Teacher.tid,tName,Course.cid,cName,cCount from

TeacherCourses,Teacher,Course where

TeacherCourses.tid=Teacher.tid and

TeacherCourses.cid=Course.cid;

#(4)

select tName from Teacher where tid in(

select tid from TeacherCourses where cid in

(select cid from Course where cName='SQL Server數據庫'));

#鏈表思路

select tName from Teacher,Course,TeacherCourses where

TeacherCourses.tid=Teacher.tid and

TeacherCourses.cid=Course.cid and cName='SQL Server數據庫';

#(5)

select max(cCount) as 最大課時數,min(cCount) 最小課時數,avg

(cCount) 平均課時數 from TeacherCourses;

#(6)

select sum(cCount) from TeacherCourses where tid=(

select tid from Teacher where tName='郭老師');

#鏈表思路

select sum(cCount) from Teacher,TeacherCourses where

Teacher.tid=TeacherCourses.tid and tName='郭老師';

#改動:若想獲得郭老師分別帶了哪些課,然后哪些課的總課時

select cid,sum(cCount) from Teacher,TeacherCourses where

Teacher.tid=TeacherCourses.tid and tName='郭老師' group by cid;

#試一試:若想獲得郭老師分別帶了哪些課,然后哪些課的課程號、課程名和

總課時

#(7)

select tid,tName from Teacher where tid in(

select tid from TeacherCourses where cCount>90);

#鏈表思路自己完成

#(8)

alter table Teacher add constraint CK_Teacher_tLevel check

(tLevel in('教授','副教授','講師','助教'));

發表評論

發表評論電子郵件地址不會被公開。 必填項已用*標注

姓名 *

電子郵件 *

在此瀏覽器中保存我的名字、電郵和網站。

總結

以上是生活随笔為你收集整理的mysql数据库关联练习_mysql数据库建立数据表的练习(附代码)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。