网上书店管理系统项目Java数据库编程实战

Posted 橙子!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了网上书店管理系统项目Java数据库编程实战相关的知识,希望对你有一定的参考价值。

大家好!最近学习完数据库系统,一直在写实战项目-网上书店管理系统。其功能一般包括:图书信息管理、用户信息管理、图书购买、图书订单查看、图书添加、图书维护等等。现在做一个总结。 **源码及搭建教程已经上传至资源!仅供下载学习。下载


文章目录

1.效果展示

2.需求功能

用户可以进行注册登陆系统,在用户的界面上,其可以进行查看网上书店里的图书类别和所在类别下的图书,根据自己的需求可在订单项目里添加订单购买自己喜欢的图书;

管理员可以通过自己的账号登录到管理员系统对书店进行管理,其可实现对图书的添加,修改,查询,和删除功能,可以查看用户的订单,修改和维护订单。添家客户的信息用以统计数据。

在构造系统时,首先从需求出发构造数据库,然后再由数据库表结合需求划分系统功能模块。这样,就把一个大的系统解成了几个小系统。这里把系统划分为了三个模块:用户登录模块,管理员模块,用户购买模块。模块分别能够实现以下功能:

  1. 登录模块:实现登录,注册功能。
  2. 管理员模块:实现对图书的添加修改和删除以及对订单的添加修改和删除功能。
  3. 用户购买模块:实现对图书的查找以及对所需图书的下单功能。

3.系统总体设计及部分代码

3.1登录模块设计

用户正确输入用户名和密码,连接到数据库,登录成功!

private void loginActionPerformed(ActionEvent evt) 
    	 String userName=this.userNameTxt.getText();
 		String password=new String(this.passwordTxt.getPassword());
 		if(StringUtil.isEmpty(userName))
 			JOptionPane.showMessageDialog(null, "用户名不能为空!");
 			return;
 		
 		if(StringUtil.isEmpty(password))
 			JOptionPane.showMessageDialog(null, "密码不能为空!");
 			return;
 		
 		CUser cuser=new CUser(userName,password);
 		Connection con=null;
 		try 
 			con=dbUtil.getCon();
 			CUser currentCUser =cuserDao.login(con,cuser);
 			if(currentCUser!=null)
				dispose();
				new CMainFrm().setVisible(true);
			else
				JOptionPane.showMessageDialog(null, "用户名或者密码错误!");
			
 		
		 catch (Exception e) 
			// TODO 自动生成的 catch 块
			e.printStackTrace();
		

3.2新用户的注册

此模块的核心是创建实例化对象。

private void registrationActionPerformed(ActionEvent evt) 
		String userName=this.userNameTxt.getText();
		String password=this.passwordTxt.getText();
		if(StringUtil.isEmpty(userName))
			JOptionPane.showMessageDialog(null, "用户名不能为空!");
			return;
		
		if(StringUtil.isEmpty(password))
			JOptionPane.showMessageDialog(null, "密码不能为空!");
			return;
		
		Registration registration= new Registration(userName,password);

		Connection con= null;
		try 
			con=dbUtil.getCon();
			int n= registrationDao.add(con, registration);
			if(n==1)
				JOptionPane.showMessageDialog(null, "注册成功!");
				resetValue();
			else
				JOptionPane.showMessageDialog(null, "注册失败!");
			

		catch(Exception e) 

		finally 
			try 
				dbUtil.closeCon(con);
			 catch (Exception e) 
				// TODO 自动生成的 catch 块
				e.printStackTrace();
				JOptionPane.showMessageDialog(null, "注册失败!");
			
		
	

3.3图书添加模块

管理员在此界面上可对系统里的图书进行查询修改和删除。

public static void main(String[] args) 
		EventQueue.invokeLater(new Runnable() 
			public void run() 
				try 
					BookAddInterFrm frame = new BookAddInterFrm();
					frame.setVisible(true);
				 catch (Exception e) 
					e.printStackTrace();
				
			
		);
	

3.4图书添加事件

此界面主要实现图书的添加功能。

/**
*图书添加事件
*/
private void bookAddActionPerformed(ActionEvent evt) 
		String bookName=this.bookNameTxt.getText();
		String author=this.authorTxt.getText();
		String price=this.priceTxt.getText();
		String bookDesc=this.bookDescTxt.getText();

		if(StringUtil.isEmpty(bookName))
			JOptionPane.showMessageDialog(null, "图书名称不能为空!");
			return;
		

		if(StringUtil.isEmpty(author))
			JOptionPane.showMessageDialog(null, "图书作者不能为空!");
			return;
		

		if(StringUtil.isEmpty(price))
			JOptionPane.showMessageDialog(null, "图书价格不能为空!");
			return;
		

		String sex="";
		if(manJrb.isSelected())
			sex="男";
		else if(femaleJrb.isSelected())
			sex="女";
		

		BookType bookType=(BookType) bookTypeJcb.getSelectedItem();
		int bookTypeId=bookType.getId();

		Book book=new Book(bookName,author, sex, Float.parseFloat(price) , bookTypeId,  bookDesc);

		Connection con=null;
		try
			con=dbUtil.getCon();
			int addNum=bookDao.add(con, book);
			if(addNum==1)
				JOptionPane.showMessageDialog(null, "图书添加成功!");
				resetValue();
			else
				JOptionPane.showMessageDialog(null, "图书添加失败!");
			
		catch(Exception e)
			e.printStackTrace();
			JOptionPane.showMessageDialog(null, "图书添加失败!");
		finally
			try 
				dbUtil.closeCon(con);
			 catch (Exception e) 
				// TODO Auto-generated catch block
				e.printStackTrace();
			
		
	

	/**
	 * 重置表单
	 */
	private void resetValue()
		this.bookNameTxt.setText("");
		this.authorTxt.setText("");
		this.priceTxt.setText("");
		this.manJrb.setSelected(true);
		this.bookDescTxt.setText("");
		if(this.bookTypeJcb.getItemCount()>0)
			this.bookTypeJcb.setSelectedIndex(0);
		
	

	/**
	 * 初始化图书类别下拉框
	 */
	private void fillBookType()
		Connection con=null;
		BookType bookType=null;
		try
			con=dbUtil.getCon();
			ResultSet rs=bookTypeDao.list(con, new BookType());
			while(rs.next())
				bookType=new BookType();
				bookType.setId(rs.getInt("id"));
				bookType.setBookTypeName(rs.getString("bookTypeName"));
				this.bookTypeJcb.addItem(bookType);
			
		catch(Exception e)
			e.printStackTrace();
		finally

		
	

3.5买家信息维护

此模块主要用于对买家信息的查找和维护。

	/**
	 * 买家信息搜索事件处理
	 */
	protected void consumerSerachActionPerformed(ActionEvent evt) 
		String s_consumerName= this.s_consumerNameTxt.getText();
		Consumer consumer=new Consumer();
		consumer.setConsumerName(s_consumerName);
		this.fillTable(consumer);
	

	private void fillTable(Consumer consumer)
		DefaultTableModel dtm=(DefaultTableModel) consumerTable.getModel();
		dtm.setRowCount(0); // 设置成0行
		Connection con=null;
		try
			con=dbUtil.getCon();
			ResultSet rs=consumerDao.list(con, consumer);
			while(rs.next())
				Vector v=new Vector();
				v.add(rs.getString("id"));
				v.add(rs.getString("consumerName"));
				v.add(rs.getString("sex"));
				v.add(rs.getString("age"));
				v.add(rs.getString("number"));
				v.add(rs.getString("bookName"));
				dtm.addRow(v);
			
		catch(Exception e)
			e.printStackTrace();
		finally 
			try 
				dbUtil.closeCon(con);
			 catch (Exception e) 
				// TODO 自动生成的 catch 块
				e.printStackTrace();
			
		
	
	/**
	 * 买家信息修改
	 */
	private void consumerUpdateActionEvet(ActionEvent evt) 
		String id=idTxt.getText();
		String consumerName=consumerNameTxt.getText();
		String sex=sexTxt.getText();
		String age=ageTxt.getText();
		String number=numberTxt.getText();
		String bookName=bookNameTxt.getText();
		if(StringUtil.isEmpty(id))
			JOptionPane.showMessageDialog(null, "请选择要修改的记录");
			return;
		
		if(StringUtil.isEmpty(consumerName))
			JOptionPane.showMessageDialog(null, "购书者名称不能为空");
			return;
		
		if(StringUtil.isEmpty(age))
			JOptionPane.showMessageDialog(null, "年龄不能为空");
			return;
		
		if(StringUtil.isEmpty(number))
			JOptionPane.showMessageDialog(null, "联系方式不能为空");
			return;
		
		if(StringUtil.isEmpty(bookName))
			JOptionPane.showMessageDialog(null, "图书名称不能为空");
			return;
		
		if(StringUtil.isEmpty(sex))
			JOptionPane.showMessageDialog(null, "性别不能为空");
			return;
		
		Consumer consumer=new Consumer(Integer.parseInt(id),consumerName,sex,age,number,bookName);
		Connection con=null;
		try 
			con=dbUtil.getCon();
			con=dbUtil.getCon();
			int modifyNum=consumerDao.update(con, consumer);
			if(modifyNum==1)
				JOptionPane.showMessageDialog(null, "修改成功");
				this.resetValue();
				this.fillTable(new Consumer());
			else
				JOptionPane.showMessageDialog(null, "修改失败");
			

		catch(Exception e) 
			e.printStackTrace();
			JOptionPane.showMessageDialog(null, "修改失败");
		finally 
			try 
				dbUtil.closeCon(con);
			 catch (Exception e) 
				// TODO 自动生成的 catch 块
				e.printStackTrace();

			
		
	

3.6订单管理模块

此模块用于图书订单管理,查找,修改,删除等功能的实现。

     /**
	 * 订单修改事件
	 */
	protected void orderUpdateActionPerformed(ActionEvent evt) 
		String id=this.idTxt.getText();
		if(StringUtil.isEmpty(id))
			JOptionPane.showMessageDialog(null, "请选择要修改的记录");
			return;
		

		String addressee=this.addresseeTxt.getText();
		String number=this.numberTxt.getText();
		String deliveryMent=this.deliveryMentTxt.getText();
		String paymentMethod=this.paymentMethodTxt.getText();
		String shippingAddress=this.shippingAddressTxt.

以上是关于网上书店管理系统项目Java数据库编程实战的主要内容,如果未能解决你的问题,请参考以下文章

Java项目:网上图书商城系统(java+SSM+Jsp+MySQL+Redis+JWT+Shiro+RabbitMQ+Vue+EasyUI)

Java项目:网上图书商城系统(java+SSM+Jsp+MySQL+Redis+JWT+Shiro+RabbitMQ+Vue+EasyUI)

JAVA学习的书单列一下

[大数据项目]-0010-基于大数据技术推荐系统算法案例实战视频教

Java并发编程实战读书笔记5 ---Executor在android中的应用

Java并发编程实战读书笔记5 ---Executor在android中的应用