如何用SQL建立一个学生成绩管理系统数据库

2024-05-16

1. 如何用SQL建立一个学生成绩管理系统数据库

首先在SQL中利用企业管理器或向导建立一个数据库,命名为学生管理系统,
启动SQL Sever服务,运行企业管理器,单击要创建数据库的服务器左边的加号图标,展开树形目录,在“数据库”节点上右击鼠标,在弹出的快捷菜单中选则“新建数据库”命令,然后按照提示一步步建立数据库,不再详细叙述。

假设学生管理系统下有三个表,分别为学生表、课程表、修课表,表的结构分别如下:
学生表(student) (
  学号(sno) 普通编码定长字符类型,长度7,主码,
  姓名(sname) 普通编码定长字符类型,长度8,非空,
  性别(ssex) 统一编码定长字符类型,长度1,
  年龄(sage) 微整型,
  所在系(sdept) 统一编码可变长字符类型,长度20
)

课程表(course) (
  课程号(cno) 普通编码定长字符类型,长度6,主码,
  课程名(cname) 统一编码定长字符类型,长度10,非空,
  学分(credit) 小整型,
  学期(semester) 小整型
)

修课表(sc)(
  学号(sno) 普通编码定长字符类型,长度7,主码,外码
  课程号(cno) 普通编码定长字符类型,长度6,主码,外码
  成绩(grade) 小整型,
  修课类别(type)普通编码定长字符类型,长度4
)

则创建表的语句分别为:
create table Student(
  Sno char(7) primary key,
  Sname char(8) not null,
  Ssex nchar(1),
  Sage tinyint,
  Sdept nvarchar(20)
)

create table Course(
  Cno char(6) primary key,
  Cname nchar(10) not null,
  Credit smallint,
  Semester smallint
)

create table SC(
  Sno char(7),
  Cno char(6),
  Grade smallint,
  Type char(4),
   primary key(Sno,Cno),
   Foreign key(Sno)    References Student (Sno),
  Foreign key(Cno)    References Course (Cno)
)

各表的结构大体如此,如有变化可自行修改。 以上数据库和表就基本建立好了,然后就可以通过数据导入或SQL语句等向数据库中添加学生的各项具体数据了。

如何用SQL建立一个学生成绩管理系统数据库

2. 如何用SQL建立一个学生成绩管理系统数据库?

首先在SQL中利用企业管理器或向导建立一个数据库,命名为学生管理系统,启动SQL Sever服务,运行企业管理器,单击要创建数据库的服务器左边的加号图标,展开树形目录,在“数据库”节点上右击鼠标,在弹出的快捷菜单中选则“新建数据库”命令,然后按照提示一步步建立数据库,不再详细叙述。假设学生管理系统下有三个表,分别为学生表、课程表、修课表,表的结构分别如下:学生表(student) (学号(sno) 普通编码定长字符类型,长度7,主码,姓名(sname) 普通编码定长字符类型,长度8,非空,性别(ssex) 统一编码定长字符类型,长度1,年龄(sage) 微整型,所在系(sdept) 统一编码可变长字符类型,长度20)课程表(course) (课程号(cno) 普通编码定长字符类型,长度6,主码,课程名(cname) 统一编码定长字符类型,长度10,非空,学分(credit) 小整型,学期(semester) 小整型)修课表(sc)(学号(sno) 普通编码定长字符类型,长度7,主码,外码课程号(cno) 普通编码定长字符类型,长度6,主码,外码成绩(grade) 小整型,修课类别(type)普通编码定长字符类型,长度4)则创建表的语句分别为:create table Student(Sno char(7) primary key,Sname char(8) not null,Ssex nchar(1),Sage tinyint,Sdept nvarchar(20))create table Course(Cno char(6) primary key,Cname nchar(10) not null,Credit smallint,Semester smallint)create table SC(Sno char(7),Cno char(6),Grade smallint,Type char(4),primary key(Sno,Cno),Foreign key(Sno)    References Student (Sno),Foreign key(Cno)    References Course (Cno))各表的结构大体如此,如有变化可自行修改。 以上数据库和表就基本建立好了,然后就可以通过数据导入或SQL语句等向数据库中添加学生的各项具体数据了。
SQL语言,是结构化查询语言(Structured Query Language)的简称。SQL语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

3. 如何用SQL建立一个学生成绩管理系统数据库

首先在SQL中利用企业管理器或向导建立一个数据库,命名为学生管理系统,
启动SQL Sever服务,运行企业管理器,单击要创建数据库的服务器左边的加号图标,展开树形目录,在“数据库”节点上右击鼠标,在弹出的快捷菜单中选则“新建数据库”命令,然后按照提示一步步建立数据库,不再详细叙述。

假设学生管理系统下有三个表,分别为学生表、课程表、修课表,表的结构分别如下:
学生表(student) (
学号(sno) 普通编码定长字符类型,长度7,主码,
姓名(sname) 普通编码定长字符类型,长度8,非空,
性别(ssex) 统一编码定长字符类型,长度1,
年龄(sage) 微整型,
所在系(sdept) 统一编码可变长字符类型,长度20
)

课程表(course) (
课程号(cno) 普通编码定长字符类型,长度6,主码,
课程名(cname) 统一编码定长字符类型,长度10,非空,
学分(credit) 小整型,
学期(semester) 小整型
)

修课表(sc)(
学号(sno) 普通编码定长字符类型,长度7,主码,外码
课程号(cno) 普通编码定长字符类型,长度6,主码,外码
成绩(grade) 小整型,
修课类别(type)普通编码定长字符类型,长度4
)

则创建表的语句分别为:
create table Student(
Sno char(7) primary key,
Sname char(8) not null,
Ssex nchar(1),
Sage tinyint,
Sdept nvarchar(20)
)

create table Course(
Cno char(6) primary key,
Cname nchar(10) not null,
Credit smallint,
Semester smallint
)

create table SC(
Sno char(7),
Cno char(6),
Grade smallint,
Type char(4),
primary key(Sno,Cno),
Foreign key(Sno)    References Student (Sno),
Foreign key(Cno)    References Course (Cno)
)

各表的结构大体如此,如有变化可自行修改。 以上数据库和表就基本建立好了,然后就可以通过数据导入或SQL语句等向数据库中添加学生的各项具体数据了。
SQL语言,是结构化查询语言(Structured Query Language)的简称。SQL语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

如何用SQL建立一个学生成绩管理系统数据库

4. 使用SQL语句在学生管理数据库中创建学生选择专业的"基本"数据表形式 如何写出这个问题的实践报告

为了大家更容易理解我举出的SQL语句,本文假定已经建立了一个学生成绩管理数据库,全文均以学生成绩的管理为例来描述。
1.在查询结果中显示列名:

a.用as关键字:select name as '姓名' from students order by age

b.直接表示:select name '姓名' from students order by age

2.精确查找:

a.用in限定范围:select * from students where native in ('湖南', '四川')

b.betweenand:select * from students where age between 20 and 30

c.“=”:select * from students where name = '李山'

d.like:select * from students where name like '李%' (注意查询条件中有“%”,则说明是部分匹配,而且还有先后信息在里面,即查找以“李”开头的匹配项。所以若查询有“李”的所有对象,应该命令:'%李%';若是第二个字为李,则应为'_李%'或'_李'或'_李_'。)

e.[]匹配检查符:select * from courses where cno like '[AC]%' (表示或的关系,与"in()"类似,而且"[]"可以表示范围,如:select * from courses where cno like '[A-C]%')

3.对于时间类型变量的处理

a.smalldatetime:直接按照字符串处理的方式进行处理,例如:


select * from students where birth > = '1980-1-1' and birth <= '1980-12-31'
4.集函数

a.count()求和,如:select count(*) from students (求学生总人数)

b.avg(列)求平均,如:select avg(mark) from grades where cno=’B2’

c.max(列)和min(列),求最大与最小

5.分组group

常用于统计时,如分组查总数:
select gender,count(sno) 
from students
group by gender

查看男女学生各有多少)

注意:从哪种角度分组就从哪列"group by"

对于多重分组,只需将分组规则罗列。比如查询各届各专业的男女同学人数,那么分组规则有:届别(grade)、专业(mno)和性别(gender),所以有"group by grade, mno, gender"select grade, mno, gender, count(*)

from students

group by grade, mno, gender
通常group还和having联用,比如查询1门课以上不及格的学生,则按学号(sno)分类有:

select sno,count(*) from grades 

where mark<60
group by sno
having count(*)>1

6.UNION联合


并查询结果,如:




SELECT * FROM students

WHERE name like ‘张%’

UNION [ALL]

SELECT * FROM students

WHERE name like ‘李%’



7.多表查询



a.内连接



select g.sno,s.name,c.coursename 

from grades g JOIN students s ON g.sno=s.sno

JOIN courses c ON g.cno=c.cno

(注意可以引用别名)

b.外连接

b1.左连接

select courses.cno,max(coursename),count(sno) 

from courses LEFT JOIN grades ON courses.cno=grades.cno 

group by courses.cno



左连接特点:显示全部左边表中的所有项目,即使其中有些项中的数据未填写完全。



左外连接返回那些存在于左表而右表中却没有的行,再加上内连接的行。



b2.右连接



与左连接类似



b3.全连接



select sno,name,major 

from students FULL JOIN majors ON students.mno=majors.mno



两边表中的内容全部显示



c.自身连接



select c1.cno,c1.coursename,c1.pno,c2.coursename 

from courses c1,courses c2 where c1.pno=c2.cno



采用别名解决问题。



d.交叉连接



select lastname+firstname from lastname CROSS JOIN firstanme



相当于做笛卡儿积



8.嵌套查询



a.用关键字IN,如查询李山的同乡:



select * from students

where native in (select native from students where name=’ 李山’)



b.使用关键字EXIST,比如,下面两句是等价的:



select * from students

where sno in (select sno from grades where cno=’B2’)



select * from students where exists 

(select * from grades where 

grades.sno=students.sno AND cno=’B2’)



9.关于排序order



a.对于排序order,有两种方法:asc升序和desc降序



b.对于排序order,可以按照查询条件中的某项排列,而且这项可用数字表示,如:



select sno,count(*) ,avg(mark) from grades 

group by sno

having avg(mark)>85

order by 3



10.其他



a.对于有空格的识别名称,应该用"[]"括住。



b.对于某列中没有数据的特定查询可以用null判断,如select sno,courseno from grades where mark IS NULL



c.注意区分在嵌套查询中使用的any与all的区别,any相当于逻辑运算“||”而all则相当于逻辑运算“&&”



d.注意在做否定意义的查询是小心进入陷阱:



如,没有选修‘B2’课程的学生 :



select students.*

from students, grades

where students.sno=grades.sno

AND grades.cno  ’B2’



上面的查询方式是错误的,正确方式见下方:



select * from students

where not exists (select * from grades 

where grades.sno=students.sno AND cno='B2')



11.关于有难度多重嵌套查询的解决思想:



如,选修了全部课程的学生:



select *

from students

where not exists ( select *

from courses

where NOT EXISTS 

(select *

from grades

where sno=students.sno

AND cno=courses.cno))
最外一重:从学生表中选,排除那些有课没选的。用not exist。由于讨论对象是课程,所以第二重查询从course表中找,排除那些选了课的即可。