作为现代程序员的必备技能,数据库技术越来越受到各路开发人员的重视和追捧。为了学习和掌握这门精深的技术,我和同学们一起完成了数据库实验一。在这项实验中,我们通过分析和设计一个实际项目的数据库并编写相应的SQL语句,深入了解了数据库的各种概念和运用。
在实验一中,我们的任务是在已给出的需求分析基础上,设计和创建一个建模成果正确且能够支持查询任务的MySQL数据库。具体来说,这个项目要求我们创建一个学生管理系统,能够对学生信息进行存储、查询和修改。我们根据该系统所需要的表格,定义并创建了三个MySQL表格:学生表格(Student)、成绩表格(Grade)和班级表格(Class)。
在设计这些表格时,我们首先考虑了表格的字段内容和数据类型。例如,学生表格中包含学号、姓名、出生年月、性别和班级等字段,这些字段的数据类型分别为字符串、日期型、布尔型等。我们还为每个表格设计了一个关键字段,用以标示和区分每个记录。然后我们通过输入相应的语句,在MySQL数据库中创建了这三个表格,并将其中的字段和数据类型定义好。
接下来的任务是编写SQL语句,将学生、成绩和班级信息录入数据库中。我们通过学生表格的insert语句,将学生信息录入数据库中;通过成绩表格的insert语句,将学生的成绩信息录入数据库中;通过班级表格的insert语句,将班级信息录入数据库中。经过这些步骤,我们成功地将这三个表格中所有的信息录入到了MySQL数据库中。
为了进一步提高数据的可读性和查询效率,我们通过合适的条件进行了SQL查询,使查询结果更加精准和快速。例如,我们通过学生和成绩表格的联合查询语句,得出了每个学生的详细信息和成绩信息;通过班级和学生表格的连接查询语句,得出了某个班级中所有学生的详细信息。这些查询结果可以方便地在后续的学生管理系统中显示和使用。
我们对整个数据库进行了分析和优化,以保证它在使用时能够达到良好的查询效率和安全性。我们对数据库的结构进行归纳和对其中可能存在的重复、错误、冗余等问题进行排除和处理。同时,我们还对数据库的性能进行了测试,以便为在后续的项目中优化数据库作出贡献。
通过这次实验,我深刻体验到了数据库技术的重要性和学习它所需要的耐心和恒心。作为一名程序员,我们需要处理海量的数据,了解和掌握这些数据的结构和关系,才能编写出高效且可靠的程序和应用。下一步,我会继续深入学习数据库技术,并在实践中探索更多的应用和技巧。
相关问题拓展阅读:
100分求一份数据库原理课程设计的实验报告
(图放不上去呀 我自己做的E-R图)
计算机科学与信息学院
课程设计报告
课程名称: 数据库概论课程设计
专 业: 网络方向
班 级: ====
学 号: ===
姓 名:闫娟
题 目: 网上购书系统
指导教师:肖淑芬
2023年6月
目录
一、课程设计的背景来源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.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”;
temp+=””+rs.getString(“name”)+””;
temp+=””+rs.getString(“sex”)+””;
temp+=””+rs.getString(“phone”)+””;
temp+=””+rs.getString(“address”)+””;
temp += “修改”;
temp += “删除”;
temp += “”;
}
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”;
temp+=””+rs.getString(“bookname”)+””;
temp+=””+rs.getString(“author”)+””;
temp+=””+rs.getString(“pubhouse”)+””;
temp+=””+rs.getString(“price”)+””;
if(f)
{
temp+=””+rs.getString(“salenum”)+””;
temp+=”修改”;
temp+=”删除”;
}
else
temp+=”加入购物车”;
temp += “”;
}
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”;
temp+=””+orderid+””;
temp+=””+(rs.getString(“orderdate”)).substring(0,10)+””;
temp+=””+rs.getString(“orderstate”)+””;
if(f)
{
temp += “”+rs.getString(“username”)+””;
temp += “删除”;
}
temp+=””;
}
catch(SQLException e) { }
return temp;
}
}
七、系统评价及心得体会
1、了解很多关于网上购书程序上的知识,要写这个课程设计,我把有关网上购书的概论也看了下,发现不知道是这个设计太简单还是怎么回事,网上出现很多此样的版本,很有有更新,可能我们对数据库设计的程序还不是很了解吧。
2,要写数据库E-R图,发现很难画啊,还要把线段连来连去,觉得在画图上面花了很多时间
3,一定要先了解数据情况,要先熟悉了网上购书的基本操作,在开始研究,更好自己去试一下网上购书,我就自己亲自去点击了下网上购书网,然后才下手写的课程设计。
数据库实验一报告书的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于数据库实验一报告书,数据库实验一:分析与报告,100分求一份数据库原理课程设计的实验报告的信息别忘了在本站进行查找喔。
转载声明:本站文章若无特别说明,皆为原创,转载请注明来源:www.88531.cn资享网,谢谢!^^