首页数据库数据库实验一 求SQL数据库实验报告

数据库实验一 求SQL数据库实验报告

编程之家2023-10-22119次浏览

今天给各位分享数据库实验一的知识,其中也会对求SQL数据库实验报告进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

数据库实验一 求SQL数据库实验报告

100分求一份数据库原理课程设计的实验报告

(图放不上去呀我自己做的E-R图)

计算机科学与信息学院

课程设计报告

课程名称:数据库概论课程设计

专业:网络方向

班级:====

数据库实验一 求SQL数据库实验报告

学号:===

姓名:闫娟

题目:网上购书系统

指导教师:肖淑芬

2011年6月

目录

数据库实验一 求SQL数据库实验报告

一、课程设计的背景来源 3

二、网上购书系统调查及前景 4

三、网上购书设计思想 4

1、前台系统工作流程 5

2、后台系统工作流程 6

四、网上书店工作过程的内容 6

五、数据库设计 7

1、数据项 7

2、数据结构 8

3、关系模式的设计 8

4、视图的设计 9

六、网上购书E-R图 10

六、系统的源程序 15

七、系统评价及心得体会 20

一、课程设计的背景来源

1,其实写这个课程设计写得比较匆忙,马上其他可就要考试了,本想找个男的题目来挑战下自己,后来还是因为时间需要,所以选了个相对来说我们生活比较容易接近的

2,随着现在社会的发展,网络已经成为一个市场很大的交易平台,很多人由于时间需要或者各方面原因都把网上购物作为一种消费方式,有时我们在书店要花很长时间去找一本书,有时还找不到,记得有次在孝感学院图书馆找一本概率论辅导书,花了很长很长时间呀,所以我深有体会,还是感觉在网上购书比较简单,方便。

3,班上有很多同学都从事网上购物,我刚好想利用自己的专业知识来学习下这方面的知识,自己查查资料,把这个课程设计做好。

二、网上购书系统调查及前景

人们喜欢通过阅览书籍拓展自己的知识视野,可在实际生活的购书过程中人们却遇到了不少麻烦,比如购书人多,挑书难,搬书重等,因此既方便又快捷的网络购书便成为了一种很有潜力的购书消费方式。信息时代,电子商务已经成为我们现实生活中不可缺少的一个重要组成部分,同时它以一种特殊的方式改变着我们的生活。根据调查结果显示,网民上网以获取信息为主要目的占5 3.1%。目前我国上网购物的群体中,绝大多数是年轻人,他们大多数是收入稳定、文化水平较高的中青年,网上消费已经日益成为他们生活中的一种重要的消费方式,他们成为了最有潜力的未来网上消费者。

三、网上购书设计思想

首先网上购书系统听起来是个很杂的程序,因为有很多很多书,也有很多很多人来买,但是其实我们简单的可以把它分为两个模块,这样我们就能很好的理解了,网上书店主要由前台会员管理模块和后台管理员模块两部分组成。

前台功能模块主要用于实现会员注册,登录,修改个人信息,分类查看书目信息、购书、管理购物车、结帐、查看各种服务条款等功能。

后台管理模块主要用于实现后台管理人员对会员,商品,物流,订单和系统的管理等功能。

1、前台系统工作流程

首先当我们用户登陆这个网站时,一开始就会出现让你登陆,如果是你会员,你可以直接登录,如果你不是会员,你要注册个账号。

1、当你是会员时,你可以查看你的各项服务,比如说上次你收藏了什么书籍,以及你喜欢的书的种类,在可以看下前几次你购买书的情况,在可以修改个人信息,修改密码等,你也可以查看自己网上交易情况,看下自己买的书的情况,以及看上什么书了,可以把它放回购物车,方便自己购买。

2、当你是非会员时,你要先进行注册,填写自己的基本信息,当你填好后,你也是其中一员了,你也同样可以向会员那样找自己的书了,相对来说比较方便。

3、还有人不注册,只是进来逛下网站,看看自己是否有必要买一些书。

2、后台系统工作流程

后台系统工作流程主要用于实现后台管理人员对会员,商品,物流,订单和系统的管理等功能,他要对会员的登记进行统计,以及购物等方面的内容管理

四、网上书店工作过程的内容

1、管理员信息,包括数据项有:管理员编号、管理员账号、管理员密码。

2、会员信息,包括数据项有:会员账号、会员密码、会员昵称、会员E-mail、会员级别(管理员设定)。

3、图书信息,包括数据项有:图书编号、图书名称、作者、出版社编号、出版日期、图书类别编号、图书简介。

(⑴出版社信息,包括数据项有:出版社编号、出版社名称。

⑵图书类别信息,包括数据项有:图书类别编号、图书类别名称。)

4、图书订单,包括数据项有:会员账号、下定单日期、收货地址、收货地址邮编、收货人姓名、收货人联系方式、送货方式编号、总费用、图书名称、现已售出量情况。

5、购物车,包括数据项有:会员账号、每种图书名称、每种图书市场价格、每种图书网站价格、每种图书数量、每种图书的价格、图书总价。

五、数据库设计

1、数据项

数据项

数据项名数据类型长度别名取值范围

会员编号字符型 15会员的编号

姓名文本型 20会员的姓名

密码文本型 20会员的密码

电话字符型 12会员的电话

地址文本型 50会员的地址

商品编号字符型 15商品的编号

类型文本型 10商品的类型

名称文本型 20商品的名称

价格整型 6商品的价格

简介文本型 500商品的简介

图片图片型商品的图片

购物车编号字符型 10购物车的编号

商品数量整型 10购买商品的数量

订单编号字符型 15购物时生成的订单

订单日期时间型 10购买商品的时间

2、数据结构

系统需求数据结构

数据结构名含义说明组成

会员记录会员的基本信息会员编号、姓名、密码、电话、地址

商品记录销售商提供的商品信息商品编号、类型、名称、价格、简介、图片

订购记录会员的购物信息会员编号、商品编号、订单编号、订单日期

购物车存储会员需要购买的商品会员编号、商品编号、购物车编号、商品数量

3、关系模式的设计

会员

数据项名数据类型长度别名是否为空主外键

会员编号字符型 15会员编号否主键

姓名文本型 20姓名否

密码文本型 20密码否

电话字符型 12电话否

地址文本型 50地址否

商品

数据项名数据类型长度别名是否为空主外键

商品编号字符型 15商品编号否主键

类型字符型 15类型否

名称字符型 20名称否

价格整型 10价格否

简介文本型 500简介

图片 image型 100图片

订购

数据项名数据类型长度别名是否为空主外键

会员编号字符型 15会员编号否外键主键

商品编号字符型 10商品编号否外键

订单编号字符型 10订单编号否

订单日期日期型 10订单日期否

购物车

数据项名数据类型长度别名是否为空主外键

会员编号字符型 15会员编号否主键

商品编号字符型 15商品编号否

购物车编号字符型 15购物车编号否

商品数量整型 6商品数量否

4、视图的设计

搜索商品视图

数据项名数据类型长度别名是否为空

名称字符型 10名称否

类型字符型 10类型否

价格整型 10价格否

简介文本型 4简介否

六、网上购书E-R图

否是

网上书店系统业务流程:

网上书店前台管理功能结构图:

六、系统的源程序

ackage cart;

import java.util.Vector;

public class Cart{

Vector v= new Vector();

String act= null;

String item= null;

private void addItem(String id){

v.addElement(id);

}

private void removeItem(String id){

v.removeElement(id);

}

public void setItem(String id){

item= id;

}

public void setAct(String s){

act= s;

}

public String[] getItems(){

String[] s= new String[v.size()];

v.copyInto(s);

return s;

}

public void processRequest(){

if(act.equals("add"))

addItem(item);

else if(act.equals("remove"))

removeItem(item);

// reset at the end of the request

reset();

}

// reset

private void reset(){

act= null;

item= null;

}

public void clearAll(){

v.removeAllElements();

}

}

现实页面信息,提示等操作的设计:

package spage;

import java.sql.*;

public class ShowPage

{

private String str="";

//显示页号为p的一页(user)

public String printPage(ResultSet rs, int p, int size)

{

str="";

//将访问游标定位到页号为p的页要显示的第一条记录的位置

try{

for(int k=0;k<(p-1)*size;k++)

rs.next();

}

catch(SQLException e){}

for(int iPage=1; iPage<=size; iPage++){

str+= printRow(rs,iPage,p);

try{

if(!rs.next()) break;

}

catch(Exception e){}

}

return str;

}

//显示单行记录(user)

public String printRow( ResultSet rs,int i,int p)

{

String temp="";

try{

int id=rs.getInt("userid");

temp+="<tr align='center' bgcolor='#FFFAF7'>";

temp+="<td><a href='javaScript:seeUser("+id+")'>"+rs.getString("name")+"</a></td>";

temp+="<td>"+rs.getString("sex")+"</td>";

temp+="<td>"+rs.getString("phone")+"</td>";

temp+="<td>"+rs.getString("address")+"</td>";

temp+="<td><a href='updateuser.jsp?updateid="+id+"'>修改</a></td>";

temp+="<td><a href='dealdeleteuser.jsp?delid="+id+"'>删除</a></td>";

temp+="</tr>";

}

catch(SQLException e){}

return temp;

}

//显示页号为p的一页(book)

public String bookPage(ResultSet rs, int p, int size,boolean f)

{

str="";

//将访问游标定位到页号为p的页要显示的第一条记录的位置

try{

for(int k=0;k<(p-1)*size;k++)

rs.next();

}

catch(SQLException e){}

for(int iPage=1; iPage<=size; iPage++){

str+= bookRow(rs,iPage,p,f);

try{

if(!rs.next()) break;

}

catch(Exception e){}

}

return str;

}

//显示单行记录(book)

public String bookRow( ResultSet rs,int i,int p,boolean f)

{

String temp="";

try{

int id=rs.getInt("bookid");

temp+="<tr align='center'>";

temp+="<td><a href='detail.jsp?detailid="+id+"'>"+rs.getString("bookname")+"</a></td>";

temp+="<td>"+rs.getString("author")+"</td>";

temp+="<td>"+rs.getString("pubhouse")+"</td>";

temp+="<td>"+rs.getString("price")+"</td>";

if(f)

{

temp+="<td>"+rs.getString("salenum")+"</td>";

temp+="<td><a href='updatebook.jsp?updateid="+id+"'>修改</a></td>";

temp+="<td><a href='dealdeletebook.jsp?delid="+id+"'>删除</a></td>";

}

else

temp+="<td><a href='dealcart.jsp?dealid="+id+"&act=add'>加入购物车</a></td>";

temp+="</tr>";

}

catch(SQLException e){}

return temp;

}

//显示页号为p的一页(order)

public String orderPage(ResultSet rs, int p, int size,boolean f)

{

str="";

//将访问游标定位到页号为p的页要显示的第一条记录的位置

try{

for(int k=0;k<(p-1)*size;k++)

rs.next();

}

catch(SQLException e){}

for(int iPage=1; iPage<=size; iPage++){

str+= orderRow(rs,iPage,p,f);

try{

if(!rs.next()) break;

}

catch(Exception e){}

}

return str;

}

//显示单行记录(order)

public String orderRow( ResultSet rs,int i,int p,boolean f)

{

String temp="";

try{

String orderid=rs.getString("orderid");

temp+="<tr align='center'>";

temp+="<td><a href='detailorder.jsp?detailid="+orderid+"'>"+orderid+"</a></td>";

temp+="<td>"+(rs.getString("orderdate")).substring(0,10)+"</td>";

temp+="<td>"+rs.getString("orderstate")+"</td>";

if(f)

{

temp+="<td><a href='javaScript:seeUser("+rs.getString("userid")+")'>"+rs.getString("username")+"</a></td>";

temp+="<td><a href='dealdeleteorder.jsp?delid="+orderid+"'>删除</a></td>";

}

temp+="</tr>";

}

catch(SQLException e){}

return temp;

}

}

七、系统评价及心得体会

1、了解很多关于网上购书程序上的知识,要写这个课程设计,我把有关网上购书的概论也看了下,发现不知道是这个设计太简单还是怎么回事,网上出现很多此样的版本,很有有更新,可能我们对数据库设计的程序还不是很了解吧。

2,要写数据库E-R图,发现很难画啊,还要把线段连来连去,觉得在画图上面花了很多时间

3,一定要先了解数据情况,要先熟悉了网上购书的基本操作,在开始研究,最好自己去试一下网上购书,我就自己亲自去点击了下网上购书网,然后才下手写的课程设计。

数据库实验总结

数据库实验总结【一】

试验内容

1、数据表的建立

基本表《简单的》带有主键

带有外码约束的(外码来自其他表或者本表)

2、数据表的修改

添加删除列

修改列属性类型

添加删除约束(约束名)

元组的添加,修改,删除

删除数据表

试验过程

1、create table student

(

sno char(9) primary key,/*sno是主码列级完整性约束条件*/

sname char(20) unique,/*sname取唯一值*/

ssex char(2),

sage smallint,/*类型为smallint*/

sdept char(20)/*所在系*/

);

create table course

(

cno char(4) primary key,/*列级完整性约束条件,cno是主码*/

cname char(40),

cpno char(4),/*cpno的含义是先行课*/

ccredit smallint,

foreign key(cpno) references course(cno)

/*表级完整性约束条件,cpno是外码,被参照表是course,被参照列是cno*/

);

create table sc

(

sno char(9),

cno char(4),

grade smallint,

primary key(sno,cno),

/*主码有两个属性构成,必须作为表级完整性进行定义*/

foreign key(sno) references student(sno),

/*表级完整性约束条件,sno是外码,被参照表是student*/

foreign key(cno) references course(cno),

/*表级完整性约束条件,cno是外码,被参照表示course*/

);

例1、create table s

(

cno varchar(3),/*变长的字符串,输入2个字符就是两个字符不会补空格*/

sname varchar(20),

status int,

city varchar(20),

constraint pk_sno primary key(sno),/*约束条件的名字为pk_sno*/

);

create table p

(

pno varchar(3),

pname varchar(20),

color varchar(3),

weight int,

constraint pk_pno primary key(pno),/*约束条件的名字是pk_pno*/

);

create table j

(

jno varchar(3),

jname varchar(20),

city varchar(20),

constraint pk_jno primary key(jno)/*约束条件的名字为pk_jno*/

);

例2、create table spj

(

sno varchar(3),/*第一个表中的主码*/

pno varchar(3),

jno varchar(3),

qty int,/*数量*/

constraint pk_spj primary key(sno,pno,jno),/*主码由3个属性组成*/

foreign key(sno) references s(sno),

/*表级完整性约束条件,sno是外码,被参照表是s*/

foreign key(pno) references p(pno),

/*表级完整性约束条件,pno是外码,被参照表是p*/

foreign key(jno) references j(jno),

/*表级完整性约束条件,jno是外码,被参照表是j*/

);

2、数据表的更改

在s表中添加一个concat列

alter table s add concat varchar(20)

在s表中删除concat列

alter table s drop column concat

更改s表 concat列的属性把长度由20改为30

alter table s alter column concat varchar(30)

联系方式名字为concat修改属性为唯一的属性名为con_concat

alter table s add constraint con_concat unique(concat)

删除约束关系con_concat

alter table s drop constraint con_concat

/*插入一个元组*/

insert into s valus(‘s1’,’精益’,20,’天津’)/*20不能写成’20’*/

试验中的问题的排除与总结:

1、在创建spj时

有三个实体所以从3个实体中取主码,还有一个数量属性也要写上

主码由那3个主码确定

2、更改一个数据库中数据表时一定要先使该数据库处于正在使用状态

3、constraint

是可选关键字,表示 primary key、not null、unique、foreign key或 check约束定义的开始。约束是特殊属性,用于强制数据完整性并可以为表及其列创建索引。

4、--go可以不加但是要注意顺序注:go--注释提示错误

5、注意添加一个空元素用 null

附 sql备份

--创建一个数据库 student

create database student

go

--在数据库student中创建表student course sc注意顺序

use student

----------------------------------------------------------------

create table student

(

sno char(9) primary key,/*sno是主码列级完整性约束条件*/

sname char(10) unique,/*sname取唯一值*/

ssex char(2),

sage smallint,/*类型为smallint*/

sdept char(20)/*所在系*/

);/*;要加*/

-----------

数据库实验总结【二】

我在sql server索引基础知识系列中,第一篇就讲了记录数据的基本格式。那里主要讲解的是,数据库的最小读存单元:数据页。一个数据页是8k大小。

对于数据库来说,它不会每次有一个数据页变化后,就存到硬盘。而是变化达到一定数量级后才会作这个操作。这时候,数据库并不是以数据页来作为操作单元,而是以64k的数据(8个数据页,一个区)作为操作单元。

区是管理空间的基本单位。一个区是八个物理上连续的页(即 64 kb)。这意味着 sql server数据库中每 mb有 16个区。

为了使空间分配更有效,sql server不会将所有区分配给包含少量数据的表。sql server有两种类型的区:

统一区,由单个对象所有。区中的所有 8页只能由所属对象使用。

混合区,最多可由八个对象共享。区中八页的每页可由不同的对象所有。

通常从混合区向新表或索引分配页。当表或索引增长到 8页时,将变成使用统一区进行后续分配。如果对现有表创建索引,并且该表包含的行足以在索引中生成 8页,则对该索引的所有分配都使用统一区进行。

为何会这样呢?

其实很简单:

读或写 8kb的时间与读或写 64 kb的时间几乎相同。

在 8 kb到 64 kb范围之内,单个磁盘 i/o传输操作所花的时间主要是磁盘取数臂和读/写磁头运动的时间。

因此,从数学上来讲,当需要传输 64 kb以上的 sql数据时,

尽可能地执行 64 kb磁盘传输是有益的,即分成数个64k的操作。

因为 64 kb传输基本上与 8 kb传输一样快,而每次传输的 sql server数据是 8 kb传输的 8倍。

我们通过一个实例来看有and操作符时候的最常见的一种情况。我们有下面一个表,

create table [dbo].[member]( [member_no] [dbo].[numeric_id] identity(1,1) not null, [lastname] [dbo].[shortstring] not null, [firstname] [dbo].[shortstring] not null, [middleinitial] [dbo].[letter] null, [street] [dbo].[shortstring] not null, [city] [dbo].[shortstring] not null, [state_prov] [dbo].[statecode] not null, [country] [dbo].[countrycode] not null, [mail_code] [dbo].[mailcode] not null, [phone_no] [dbo].[phonenumber] null, [photograph] [image] null, [issue_dt] [datetime] not null default(getdate()), [expr_dt] [datetime] not null default(dateadd(year,1,getdate())), [region_no] [dbo].[numeric_id] not null, [corp_no] [dbo].[numeric_id] null, [prev_balance] [money] null default(0), [curr_balance] [money] null default(0), [member_code] [dbo].[status_code] not null default(''))

这个表具备下面的四个索引:

索引名细节索引的列

member_corporation_link nonclustered located on primary corp_no

member_ident clustered, unique, primary key located on primary member_no

member_region_link nonclustered located on primary region_no

memberfirstname nonclustered located on primary firstname

当我们执行下面的sql查询时候,

select m.member_no, m.firstname, m.region_nofrom dbo.member as mwhere m.firstname like'k%' and m.region_no> 6 and m.member_no< 5000go

sql server会根据索引方式,优化成下面方式来执行。

select a.member_no,a.firstname,b.region_nofrom(select m.member_no, m.firstname from dbo.member as m where m.firstname like'k%' and m.member_no< 5000) a,--这个查询可以直接使用 memberfirstname非聚集索引,而且这个非聚集索引覆盖了所有查询列--实际执行时,只需要逻辑读取 3次

(select m.member_no, m.region_no from dbo.member as mwhere m.region_no> 6) b

--这个查询可以直接使用 member_region_link非聚集索引,而且这个非聚集索引覆盖了所有查询列--实际执行时,只需要逻辑读取 10次

where a.member_no= b.member_no

不信,你可以看这两个sql的执行计划,以及逻辑读信息,都是一样的。

其实上面的sql,如果优化成下面的方式,实际的逻辑读消耗也是一样的。为何sql server不会优化成下面的方式。是因为 and操作符优化的另外一个原则。

1/26的数据和 1/6的数据找交集的速度要比 1/52的数据和 1/3的数据找交集速度要慢。

select a.member_no,a.firstname,b.region_nofrom(select m.member_no, m.firstname from dbo.member as mwhere m.firstname like'k%'-- 1/26数据) a,

(select m.member_no, m.region_no from dbo.member as mwhere m.region_no> 6 and m.member_no< 5000-- 1/3* 1/ 2数据) bwhere a.member_no= b.member_no

当然,我们要学习sql如何优化的话,就会用到查询语句中的一个功能,指定查询使用哪个索引来进行。

比如下面的查询语句

select m.member_no, m.firstname, m.region_nofrom dbo.member as m with(index(0))where m.firstname like'k%' and m.region_no> 6 and m.member_no< 5000go

select m.member_no, m.firstname, m.region_nofrom dbo.member as m with(index(1))where m.firstname like'k%' and m.region_no> 6 and m.member_no< 5000goselect m.member_no, m.firstname, m.region_nofrom dbo.member as m with(index(membercovering3))where m.firstname like'k%' and m.region_no> 6 and m.member_no< 5000goselect m.member_no, m.firstname, m.region_nofrom dbo.member as m with(index(memberfirstname, member_region_link))where m.firstname like'k%' and m.region_no> 6 and m.member_no< 5000go

这里 index计算符可以是 0,1,指定的一个或者多个索引名字。对于 0,1的意义如下:

如果存在聚集索引,则 index(0)强制执行聚集索引扫描,index(1)强制执行聚集索引扫描或查找(使用性能最高的一种)。

如果不存在聚集索引,则 index(0)强制执行表扫描,index(1)被解释为错误。

总结知识点:

简单来说,我们可以这么理解:sql server对于每一条查询语句。会根据实际索引情况(sysindexes系统表中存储这些信息),分析每种组合可能的成本。然后选择它认为成本最小的一种。作为它实际执行的计划。

成本代价计算的一个主要组成部分是逻辑i/o的数量,特别是对于单表的查询。

and操作要满足所有条件,这样,经常会要求对几个数据集作交集。数据集越小,数据集的交集计算越节省成本。

的项目中,竟然出现了滥用聚集索引的问题。看来没有培训最最基础的索引的意义,代价,使用场景,是一个非常大的失误。这篇博客就是从这个角度来罗列索引的基础知识。

使用索引的意义

索引在数据库中的作用类似于目录在书籍中的作用,用来提高查找信息的速度。

使用索引查找数据,无需对整表进行扫描,可以快速找到所需数据。

使用索引的代价

索引需要占用数据表以外的物理存储空间。

创建索引和维护索引要花费一定的时间。

当对表进行更新操作时,索引需要被重建,这样降低了数据的维护速度。

创建索引的列

主键

外键或在表联接操作中经常用到的列

在经常查询的字段上最好建立索引

不创建索引的列

很少在查询中被引用

包含较少的惟一值

定义为 text、ntext或者 image数据类型的列

heaps是staging data的很好选择,当它没有任何index时

excellent for high performance data loading(parallel bulk load and parallel index creation after load)

excellent as a partition to a partitioned view or a partitioned table

聚集索引提高性能的方法,在前面几篇博客中分别提到过,下面只是一个简单的大纲,细节请参看前面几篇博客。

何时创建聚集索引?

clustered index会提高大多数table的性能,尤其是当它满足以下条件时:

独特,狭窄,静止:最重要的条件

持续增长的,最好是只向上增加。例如:

identity

date, identity

guid(only when using newsequentialid() function)

聚集索引唯一性(独特型的问题)

由于聚集索引的b+树结构的叶子节点必须指向具体数据。如果你要建立聚集索引的列不唯一,并且你指定的创建的聚集索引是非唯一的聚集索引,则会有以下情况:

如果未使用 unique属性创建聚集索引,数据库引擎将向表自动添加一个四字节 uniqueifier列。必要时,数据库引擎将向行自动添加一个 uniqueifier值,使每个键唯一。此列和列值供内部使用,用户不能查看或访问。

求SQL数据库实验报告

*****系实验(上机)报告

课程名称数据库系统基础

实验名称数据查询与存储过程

学号 33

学生姓名嘻习喜戏

成绩

年月日

序号 5实验名称 SQL数据查询

实验目的:

熟练掌握SQL SELECT语句,能够运用该语句完成各种查询。

实验内容:

用SQL SELECT语句完成下列查询:

1.查询客户表中的所有记录。

2.从订购单表中查询客户号信息(哪些客户有订购单)。

3.查询单价在20元以上(含)的产品信息。

4.查询单价在20元以上(不含)的产品名称为牛奶的产品信息。

5.查询单价在20元以上(不含)的产品名称为牛奶或德国奶酪的产品信息。

6.查询有2003年7月订购单的客户名称、联系人、电话号码和订单号信息。

7.查询有德国奶酪订货的客户的名称、联系人和电话号码信息。

8.查询有德国奶酪订购需求的订单名细记录。

9.查询所有订购数量(即订单名细中每个订购项目的数量)都在10个以上的订购单的信息。

10.找出和德国奶酪同等价位的所有产品信息。

11.查询单价范围在10元到30元范围内的产品信息(使用BETWEEN…AND)。

12.从客户表中查询出客户名称中有“公司”二字的客户信息(使用LIKE运算符)。

13.从客户表中查询出客户名称中没有“公司”二字的客户信息(使用NOT LIKE运算符)。

14.按产品的单价升序列出全部产品信息。

15.先按产品名称排序,再按单价排序列出全部产品信息。

16.从产品表中查询共有几种产品。

17.从订购名细表中查询德国奶酪的订购总数。

18.计算德国奶酪所有订购的总金额。

19.求所有订购单的平均金额,在查询结果中列出订购单的个数和平均金额。

20.求每个订购单订购的项目数和总金额。

21.求每个客户包含了德国奶酪订购的订单号及其最高金额和最低金额。

22.求至少有两个订购项目的订购单的平均金额。

23.找出尚未最后确定订购单(即订购日期为空值的记录)的有关客户信息(客户的名称、联系人和电话号码)和订单号。

24.找出在2000年1月1日之后签订的订购单的客户信息(客户的名称、联系人和电话号码)、订单号和订购日期。

25.列出每类产品(相同名称)具有最高单价的产品信息(产品号、名称、规格说明和单价,提示:使用内外层互相关嵌套查询)。

26.确定哪些客户目前没有订购单(使用谓词NOT EXISTS)。

27.查询目前有订购单的客户的信息(使用谓词EXISTS)。

28.查询符合条件的产品信息,要求该产品的单价达到了任意一款产品名称为牛奶的单价的一半(使用ANY或SOME量词)。

29.查询符合条件的产品信息,要求该产品的单价大于任何一款产品名称为牛奶的单价(使用ALL量词)。

30.设计如下的连接操作,并分析各自的特点:

•广义笛卡儿积

•内连接

•外连接

•左连接

•右连接

•全连接

掌握存储过程的创建命令,按照题目要求创建存储过程,理解存储过程的作用。

(1)建立存储过程。查询单价范围在x元到y元范围内的产品信息。

(2)建立存储过程。查询在某年某月某日之后签订的订购单的客户信息(客户的名称、联系人和电话号码)、订单号和订购日期。

(3)建立存储过程。将某产品的订购日期统一修改为一个指定日期。

(4)建立存储过程。删除没有签订单的客户信息。

实验要求:

用SELECT语句完成本次实验,并提交上机报告。

(1)掌握存储过程的创建命令,按照实验内容的要求创建存储过程,理解存储过程的作用。

(2)用CREATE PROCEDURE和EXECUTE语句完成本次实验,并提交上机报告。

实验准备(本实验预备知识和为完成本实验所做的准备):

仔细阅读课本第五章关于SQL的数据查询功能的内容

实验过程(实验的操作过程、遇到的问题及其解决办法或未能解决的问题):

用SQL SELECT语句完成以上30题查询

实验总结(总结本次实验的收获、未解决的问题以及体会和建议等):

熟练掌握SQL SELECT语句,能够运用该语句完成各种查询

附录(SQL语句):

--1.查询客户表中的所有记录。

select* from客户

--2.从订购单表中查询客户号信息(哪些客户有订购单)

select客户号from订单where订单号!=null

--3.查询单价在元以上(含)的产品信息。

select*from产品where单价> 20 or单价=20

--4.查询单价在元以上(不含)的产品名称为牛奶的产品信息。

select*from产品where单价>20 and产品名称='牛奶'

--.查询单价在元以上(不含)的产品名称为牛奶或德国奶酪的产品信息

select*from产品where单价>20 and(产品名称='牛奶'or产品名称='德国奶酪')

--6.查询有年月订购单的客户名称、联系人、电话号码和订单号信息

select客户名称,联系人,电话,订单号from客户,订单where(year(订购日期)=2003 and month(订购日期)=7)and(订单.客户号=客户.客户号)

--7.查询有德国奶酪订货的客户的名称、联系人和电话号码信息。

select客户名称,联系人,电话from客户

where

(客户号=(select客户号from订单where(订单号=(select订单号from订单明细

where产品号=( select产品号from产品where产品名称='德国奶酪')))))

--8.查询有德国奶酪订购需求的订单名细记录。

select* from订单明细where(数量!=null and产品号=(select产品号from产品where产品名称='德国奶酪'))

--9.查询所有订购数量(即订单名细中每个订购项目的数量)都在个以上的订购单的信息。

select* from订单where(订单号in(select订单号from订单明细where(数量>10)))

--10.找出和德国奶酪同等价位的所有产品信息。

select* from产品where(

--11.查询单价范围在元到元范围内的产品信息(使用BETWEEN…AND)。

select* from产品where(单价between 10 and 30)

--12.从客户表中查询出客户名称中有“公司”二字的客户信息(使用LIKE运算符)

select* from客户where客户名称like'%公司%'

--13.从客户表中查询出客户名称中没有“公司”二字的客户信息(使用NOT LIKE运算符)。

select* from客户where客户名称not like'%公司%'

--14.按产品的单价升序列出全部产品信息。

select*from产品order by单价

--15.先按产品名称排序,再按单价排序列出全部产品信息。

select* from产品order by产品名称,单价

--16.从产品表中查询共有几种产品。

select count( distinct产品名称) as产品总数from产品

--17.从订购名细表中查询德国奶酪的订购总数

select sum(数量) as'订购奶酪数量'

from订单明细

where产品号in(select产品号from产品where产品名称='德国奶酪')

--18.计算德国奶酪所有订购的总金额

declare@a money

select@a=(select单价from产品where产品名称='德国奶酪')

declare@b int

select@b=(select sum(数量) as'订购奶酪数量'

from订单明细

where产品号in(select产品号from产品where产品名称='德国奶酪'))

declare@c int

select@c=@a*@b

select@c as总金额

--19.求所有订购单的平均金额,在查询结果中列出订购单的个数和平均金额。

select订单均值= avg(单价*数量),订单个数=count(订单号)

from订单明细,产品

where产品.产品号=订单明细.产品号

--20.求每个订购单订购的项目数和总金额。

select订单号, count(产品.产品号) as项目数,sum(数量*单价) as总金额

from产品,订单明细

where(产品.产品号=订单明细.产品号)

group by订单号

--21.求每个客户包含了德国奶酪订购的订单号及其最高金额和最低金额

select客户.客户号,产品.产品号,数量*单价as总金额

from客户,订单,订单明细,产品

where客户.客户号=订单.客户号and订单.订单号=订单明细.订单号and订单明细.产品号=产品.产品号and

产品名称='德国奶酪'

order by客户号

compute max(数量*单价),min(数量*单价) by客户号

--22.求至少有两个订购项目的订购单的平均金额

select订单号,avg(数量*单价),count(产品.产品号)

from订单明细,产品

where订单明细.产品号=产品.产品号

group by订单号

having count(产品.产品号)>=2

--23.找出尚未最后确定订购单(即订购日期为空值的记录)的有关客户信息

--(客户的名称、联系人和电话号码)和订单号

select客户名称,联系人,电话,订单明细.订单号

from客户,订单明细,订单

where(客户.客户号=订单.客户号) and订购日期=null

--24.找出在年月日之后签订的订购单的客户信息

--(客户的名称、联系人和电话号码)、订单号和订购日期

select客户名称,联系人,电话,订单号,订购日期

from客户,订单

where客户.客户号=订单.客户号

and year(订购日期)>1996 and month(订购日期)>4 and day(订购日期)>2

--25.列出每类产品(相同名称)具有最高单价的产品信息

--(产品号、名称、规格说明和单价,提示:使用内外层互相关嵌套查询)

select A.产品号, A.产品名称, A.规格说明, A.单价

from产品A

where单价=(SELECT MAX(单价)

FROM产品B

WHERE A.规格说明= B.规格说明)

--26.确定哪些客户目前没有订购单(使用谓词NOT EXISTS)

select*

from客户

where not exists(select* from订单where客户号=订单.客户号)

--27.查询目前有订购单的客户的信息(使用谓词EXISTS)

select*

from客户

where exists(select* from订单where客户号=订单.客户号)

--28.查询符合条件的产品信息,要求该产品的单价达到了任

--意一款产品名称为牛奶的单价的一半(使用ANY或SOME量词)

select*

from产品a

where(单价>any(select单价/2 from产品b where b.产品名称='牛奶'))

--29.查询符合条件的产品信息,要求该产品的单价大于任何

--一款产品名称为牛奶的单价(使用ALL量词)

select*

from产品a

where(单价>all(select单价from产品b where b.产品名称='牛奶'))

--30.设计如下的连接操作,并分析各自的特点:

--•广义笛卡儿积

SELECT*

FROM客户CROSS JOIN订购单

WHERE客户.客户号=订购单.客户号

--•内连接

SELECT*

FROM客户INNER JOIN订购单

ON客户.客户号=订购单.客户号

--•外连接

--•左连接

SELECT*

FROM客户LEFT JOIN订购单

ON客户.客户号=订购单.客户号

--•右连接

SELECT*

FROM客户RIGHT JOIN订购单

ON客户.客户号=订购单.客户号

--•全连接

SELECT*

FROM客户FULL JOIN订购单

ON客户.客户号=订购单.客户号

说明:

1.上机报告上传到211.68.36.251的数据库文件夹中的上传目录

2.文件名的命名规则为:学号+姓名+实验+序号。如:9724101汪伟的第二次上机报告名为:9724101汪伟实验2

3.封面由学生填写;

4.正文的实验名称、实验目的、实验内容、实验要求已经由教师指定;

5.实验准备由学生在实验或上机之前填写;

6.实验过程由学生记录实验的过程,包括操作过程、遇到哪些问题以及如何解决等;

7.实验总结由学生在实验后填写,总结本次实验的收获、未解决的问题以及体会和建议等;

8.将相关的语句粘贴到附录中。

你自己改改吧。想要word原版的话再说一声。

关于本次数据库实验一和求SQL数据库实验报告的问题分享到这里就结束了,如果解决了您的问题,我们非常高兴。

数据库关键字,什么是数据表的“关键字”无法连接服务器1-10087(手机联通显示1_10087无法连接到服务器是什么意思)