ipage邮箱,邮箱ip地址

hacker|
71

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

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

计算机科学与信息学院

课程设计报告

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

专 业: 网络方向

班 级: ====

学 号: ===

姓 名: 闫娟

题 目: 网上购书系统

指导教师: 肖淑芬

2011年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.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+="tda 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 += "tda href='updateuser.jsp?updateid="+id+"'修改/a/td";

temp += "tda 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+="tda 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+="tda href='updatebook.jsp?updateid="+id+"'修改/a/td";

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

}

else

temp+="tda 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+="tda 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 += "tda href='javaScript:seeUser("+rs.getString("userid")+")'"+rs.getString("username")+"/a/td";

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

}

temp+="/tr";

}

catch(SQLException e) { }

return temp;

}

}

七、系统评价及心得体会

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

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

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

跪求!!!逆水寒耽美小说cp:雷戚,无戚(和其它戚受文)

all戚文《君子好逑》,《冤家路窄》,顾戚 卿本佳人,奈何做攻,已发

你可以去同天下论坛看文,里面都是戚受,还有仙文飘飘

;p_iPageNo=2p_sShowType=tablep_iIsOldNote=0

哪里有速度快稳定的空间,最好是国外的

使用空间做论坛的话 速度肯定会有影响的

美国几个机房的速度来说

美国圣安娜KT 洛杉矶AK 这些机房的速度都是快的 离大陆比较近

FDC的带宽比较足 而且不限制流量

SK的硬防比较好

SL的话 主要是企业客户 外贸类速度超快

巴拿马的 主要放防牌

有需要 请咨询

sql分完页,显示页码的问题

只是一个判断,以下是ASP的写法,以前后5页判断:

'iPageNo表示当前页,iPageCount表示总页数

dim iPageStart,iPageEnd

iPageStart=iPageNo-5

if iPageStart1 then iPageStart=1

iPageEnd=iPageNo+5

if iPageEndiPageCount then iPageEnd=iPageCount

if iPageStart1 then response.write "a href='?p="(iPageStart-5)"'.../a"

for i=iPageStart to iPageEnd

if iiPageNo then

response.write "a href='?p="i"'"i"/a "

else

response.write i" "

end if

next

if iPageEndiPageCount then response.write "a href='?p="(iPageNo+5)"'.../a"

基本上就是这样的,可能还有一部分判断的小调整

ipage主机购买教程

sorry!百度图片没法发!你凑和着看吧!假如不行,你就到这个网址去看。

Ipage介绍-IPage购买指南

IPage 提供的主机配置包括无限空间、无限个Email账户绑定、每月无限流量、曾屡获业界殊荣的反垃圾邮件解决方案、免费webmail、全功能电子商务购物车系统、SSL数字证书、Mysql数据库、PHP、CGI语言支持等等。

IPage提供的支付方式:PayPal和信用卡

IPage退款保证:IPage提供任何时间无条件退款(30天内全额退款,30天后按使用比例退款),也就是说你可以在任何时间无需任何理由就可以得IPage的退款,这表明了IPage对于他们主机的信心。

IPage售后支持:IPage提供24/7全天候在线技术支持,你可以通过免费800电话,电子邮件,在线聊天等获得IPage的支持,一般一个问题得到回复

现在IPage的价格为:54美元/年,折合人民币仅仅360多元,绝对超低价格。

IPage注册教程

1、进入IPage首页http//,点击“Sign up now”如图所示:

2、选择域名,你可以在IPage上注册一个域名,这个域名是免费的,只要你的主机在IPage,域名就一直免费,输入域名后,点击continue,如图:

3、下面一部需要在IPage创建账户和付款信息,输入你的姓,名,地址等信息,如图:

4、以上所示的是个人信息,中间的是付款信息,你可以选择PayPal和信用卡在线支付,信用卡(信用卡信息按如下图所示信息填写)是即时扣费,PayPal需跳转到贝宝网站支付才可,如图:

5、购买期限,一年为54美元,两年为108美元,在下面的域名信息保护(domain privacy)无需打勾,否则要多扣8.99美元,如图:

6、下面是一下IPage的附加服务,通常我们都不需要,无需打勾,如图:

7、最后一步,点击check out 进行支付,如果是信用卡,则自己会扣费,如果是选择PayPal,需跳转到PayPal进行操作。到这里,IPage美国主机就购买成功啦,等这在你的邮箱里收取账户信息吧!

请问谁有asp.net 的文章分页代码?

你是用codeSmith 做的嘛? 不知道你想要那种?

using System;

using System.Data;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.Data.OleDb;

public partial class admin_MainOrder

{

protected static int iPageCount =0;//所有记录一共分成几页,这个是系统自动算出来的

protected static int curPage = 1;//当前显示第几页

protected static bool IsFirst = false;//当前页是否是首页

protected static bool IsLast = false;//当前页是否是尾页

protected static int iPageSize = 10;//每页显示几条

protected void Page_Load(object sender, EventArgs e)

{

if (!Page.IsPostBack)

BindControls();

}

void BindControls()

{

if (Request.QueryString["Page"] != null)

curPage = Convert.ToInt32(Request.QueryString["Page"]);

else

curPage = 1;

string SQL = "SELECT Q1.*,(SELECT Name FROM Hard WHERE ID=Q1.Q_Hard) AS Q_Hard1,"+

"(SELECT TypeName FROM QuestionType WHERE ID=Q1.Q_Type) AS Q_Type1,"+

"(SELECT TypeName FROM SortType WHERE ID=Q1.Q_Sort) AS Q_Sort1 FROM Questions Q1";

DataView odv=new DataView();

odv = DBFun.CreateAccessView(SQL);

//分页 PagedDataSource这个对象是系统自定义的,直接调用就可以实现分页了

PagedDataSource opds = new PagedDataSource();

opds.DataSource = odv; //获取数据源

opds.AllowPaging = true; //是否在数据绑定中启用分页

opds.PageSize = iPageSize; //每页显示几条

opds.CurrentPageIndex = curPage - 1;//获取当前页索引,这句必须加上

lblCurrentPage.Text = "第" + curPage.ToString() + "页/共"+opds.PageCount+"页 ";

iPageCount = opds.PageCount;//共几页系统自动算出来

IsFirst = opds.IsFirstPage;

IsLast = opds.IsLastPage;

gridQuestion.DataSource = opds;//gridQuestion是GridView名

gridQuestion.DataBind();//绑定

}

//跳转

protected void lnkGoTo_Click(object sender, EventArgs e)

{

if (txtPage.Text.Trim() == "")

return;

string sAoto = txtPage.Text.Trim().ToString();

if (!Fun.IsInteger(sAoto))

return;

if (Convert.ToInt32(sAoto) 0 Convert.ToInt32(sAoto) = iPageCount)

{

string slnkGoto = Request.CurrentExecutionFilePath + "?Page=" + sAoto;

Response.Redirect(slnkGoto);

}

}

//更新

protected void lnkUpdate_Click(object sender, EventArgs e)

{

if (txtShow.Text.Trim() == "")

return;

string sAoto = txtShow.Text.Trim().ToString();

if (!Fun.IsInteger(sAoto))

return;

if (Convert.ToInt32(sAoto)0 Convert.ToInt32(sAoto) 51)

{

iPageSize = Convert.ToInt32(sAoto);

Response.Redirect(Request.CurrentExecutionFilePath);

}

}

//首页

protected void lnkFirst_Click(object sender, EventArgs e)

{

if (iPageCount != 0)

{

string slnk = Request.CurrentExecutionFilePath;

Response.Redirect(slnk);

}

}

//上一页

protected void lnkPrev_Click(object sender, EventArgs e)

{

if (iPageCount != 0 !IsFirst)

{

string slnk = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(curPage-1);

Response.Redirect(slnk);

}

}

//下一页

protected void lnkNext_Click(object sender, EventArgs e)

{

if (iPageCount != 0 !IsLast)

{

string slnk = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(curPage +1);

Response.Redirect(slnk);

}

}

//末页

protected void lnkLast_Click(object sender, EventArgs e)

{

if (iPageCount != 0)

{

string slnk = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(iPageCount);

Response.Redirect(slnk);

}

}

}

前面的序号没有填上,我这里补充下

为gridQuestion 控件DataBound 添加AddOrderId事件

protected void AddOrderId(object sender, EventArgs e)

{

for (int i = 0; i gridQuestion.Rows.Count; i++)

{

//int OrderID = gridQuestion.Rows.RowIndex+1;

int OrderID = curPage * iPageSize - iPageSize + 1;

gridQuestion.Rows.Cells[0].Text = (OrderID + i).ToString();

}

}

5条大神的评论

  • avatar
    访客 2022-09-21 下午 01:33:54

    能。1、前台系统工作流程 首先当我们用户登陆这个网站时,一开始就会出现让你登陆,如果是你会员,你可以直接登录,如果你不是会员,你要注册个账号。1、 当你是会员时,你可以查看你的各项服务,比如说上次你收藏了什么书籍,以及你喜欢的

  • avatar
    访客 2022-09-21 上午 08:24:18

    ring("orderdate")).substring(0,10)+"/td"; temp+="td"+rs.getString("orderstate")+"/td"; if(f) { temp += "tda

  • avatar
    访客 2022-09-21 下午 01:54:56

    (rs,iPage,p,f); try { if(!rs.next()) break; } catch(Exception e) { } } r

  • avatar
    访客 2022-09-21 下午 04:00:24

    面信息,提示等操作的设计:package spage;import java.sql.*;public class ShowPage{ private String str = ""; //显示页号为p的一页(user) public String pr

  • avatar
    访客 2022-09-21 下午 02:43:25

    t != 0) { string slnk = Request.CurrentExecutionFilePath + "?Page=" + Convert.ToString(iPageC

发表评论