(一)项目功能分析

   该项目是设计一个图书管理系统,主要包含的内容有:

    (1)管理员登陆界面

      ->信息录入

      ->登录

      ->重置  

    (2)图书管理系统总界面

      ->子界面菜单:

        1)图书类别添加子界面:

          ->图书类别信息录入

          ->图书类别添加

          ->图书类别信息重置

        2)图书类别管理子界面:

          ->显示所有的图书类别

          ->查询图书类别

          ->修改的图书类别信息显示

          ->修改图书类别信息

          ->删除图书类别

        3)图书添加子界面:

          ->图书信息录入

          ->图书添加

          ->图书信息重置

        4)图书管理子界面:

          ->显示所有的图书

          ->查询图书

          ->修改的图书信息显示

          ->修改图书信息

          ->删除图书

        5)关于我们:

          ->显示项目名称

(二)项目设计准备工作:

  技术:swing+jdbc+mysql.

  开发工具:eclipse+windowbuilder+sqlyog

(三)设计模式

  该项目采用类MVC设计思想,主要将代码放入四个包中,分别是:

  (1)util包:存放一些工具类,例如DBUtil,用于获取数据库连接和关闭数据库连接。

  (2)dao包:存放一些数据库访问对象,执行数据的增删改查。例如BookDao类。

  (3)model包:存入项目中的一些实体对象。例如Book类。

  (4)view包:存入项目的界面设计(其中包括程序的控制逻辑代码C)。例如管理登录界面。

(四)项目的实现

  该项目主要是按照界面的设计顺序:

  (1)创建项目BookManager,并创建四个包——util、dao、model和view

  (2)导入mysql的驱动jar包——mysql-connector-java-5.1.36.jar

  (3)在项目src下创建images文件夹,添加项目所需图片

  (4)利用sqlyog创建mysql数据库db_book,并在里面添加三张表t_user , t_book , t_bookType

  (4)创建数据库工具类:DBTool类

    ->创建db.properties文件,并在文件里存入数据库驱动driver,数据库地址url,数据库用户user,数据库密码password。

    ->创建DBTool类,在类中利用静态代码块实现获取db.properties中的各个参数。

    ->创建两个方法用于获取数据库库连接和关闭数据库连接。

  (5)管理员登录界面的实现

    ->在数据库表t_user插入管理员信息

    ->在项目model包中创建按JavaBean规范创建User实体类。

    ->在dao包中创建UserDao类,并在其中创建login()方法,用于验证管理员登录信息是否正确

    ->在view包中创建LoginFrame类,利用windowbuilder插件进行登录界面设计

    ->重置事件处理

    ->登录事件处理(信息正确进入主界面)

  (5)图书管理系统主界面的实现

      

    ->在view包中创建MainFrame类,利用windowbuilder插件进行登录界面设计

    ->在主界面添加菜单栏,并进行如下菜单结构设计

      ->基本数据维护(菜单)

        ->图书类别管理(菜单)

          ->图书类别添加(菜单项)

          ->图书类别维护(菜单项)

        ->图书管理(菜单)

          ->图书添加(菜单项)

          ->图书维护(菜单项)

        ->安全退出(菜单项)

      ->关于我们(菜单)

        ->关于我们(菜单项)

    ->为每个菜单项添加事件,没点击一个菜单项,都会进入到一个子界面中。

  (6)依照菜单项,依次设计子界面以及逻辑代码。

    ->图书类别添加子界面——BookTypeAddInterFrame

      

    ->图书类别维护子界面——BookTypeManageInterFrame

      

    ->图书添加子界面——BookAddInterFrame

      

    ->图书维护子界面——BookManageInterFrame

      

    ->安全退出

      dsipose()方法,释放窗体资源。

    ->关于我们子界面——LibraryInterFrame

      

      

  

      

Java swing项目-图书管理系统(swing+mysql+jdbc)的更多相关文章

  1. Java swing项目-图书管理系统(swing+mysql+jdbc) 总结

    (一)java Swing的学习. (1)学习如何安装windowbuilder插件的安装. <1>在eclipse中点击help <2>在help的下拉选中选择install ...

  2. java web 项目 图书管理系统的设计与实现

     java web 项目 图书管理系统的设计与实现

  3. 简单的员工管理系统(Mysql+jdbc+Servlet+JSP)

    员工管理系统 因为学业要求,需要完成一个过关检测,但是因为检测之前没有做好准备,且想到之前用mysql+jdbc+Struts2+bootstrap做成了一个ATM系统(主要有对数据的增删改查操作), ...

  4. ORM练习项目-图书管理系统(BMS)实现细节

    分析 一本书 可以由多个作者编著 一本书只能由一个出版社出版 一个作者可以写多本书 每个作者有自己的简介 对应关系: Author-Book # 多对多 Publish-Book # 一对多 Auth ...

  5. javac 编译java文件提示: 程序包com.mysql.jdbc不存在

    需要将引用的包放到:/usr/java/jdk1.7.0_75/jre/lib/ext 也就是jdk安装目录/jre/lib/ext   目录下面

  6. JAVA图书管理系统汇总共27个

    好多人都在搜索图书管理系统,感觉这个挺受欢迎的,所以整理了一系列的图书管理系统,让大家选择.java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/683 ...

  7. JAVA图书管理系统汇总共27个[转]

    java图书馆管理系统[优秀毕业设计论文+源码]http://down.51cto.com/data/68350java+sql server图书管理系统 http://down.51cto.com/ ...

  8. java链接MySQL数据库时使用com.mysql.jdbc.Connection的包会出红线问题 java.lang.ClassNotFoundException: com.mysql.jdbc.Driver问题

    package com.swift; //这里导入的包是java.sql.Connection而不是com.mysql.jdbc.Connection import java.sql.Connecti ...

  9. Mybatis批量更新报错com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException

    批量更新数据,非常简单的一段代码,硬是报错,插入的数据也能显示出来 List<User> userlist = new ArrayList<User>(); userlist. ...

随机推荐

  1. vb6获取字符串长度

    用过VB5.0或者更早版本的读者应该知道VB有一个测试字符串长度的函数: Len.但当你升级到VB6时,会发现这里的Len并没有以前那么好用了——它变成了测试字符个数而不是字符串长度.就是说,当你用以 ...

  2. Apache Shiro系列教程之三:Shiro的结构

    Shiro的设计目标是简化应用的安全管理工作.软件通常是以用户为基础设计的.也就是说,我们经常是根据用户是怎样和我们的软件交互的来设计相关的用户接口.比如,你可能会说"如果是已经登录的用户与 ...

  3. javascript中的对象之间继承关系

    相信每个学习过其他语言的同学再去学习JavaScript时就会感觉到诸多的不适应,这真是一个颠覆我们以前的编程思想的一门语言,先不要说它的各种数据类型以及表达式的不同了,最让我们头疼,恐怕就是面向对象 ...

  4. .net中常用的几种页面间传递参数的方法

    转自:http://www.cnblogs.com/lxshanye/archive/2013/04/11/3014207.html 参考:http://www.cnblogs.com/zhangka ...

  5. git秘钥配置--转

    git是分布式的代码管理工具,远程的代码管理是基于ssh的,所以要使用远程的git则需要ssh的配置.github的ssh配置如下:一 .设置git的user name和email:$ git con ...

  6. SQL Server DBA日常查询视图_数据库性能视图

    1.获取有关按平均CPU 时间排在最前面的五个查询的信息 total_worker_time/execution_count AS [Avg CPU Time], ), ((CASE qs.state ...

  7. <s:select>下拉框是空白的解决办法

    首先,定义了一个Department的JavaBean对象如下 DAO.java 在一个Action类Employee.java中将depts放入requestMap中 最后,在index.jsp里定 ...

  8. angularjs的touch事件

    angularJs没有touch事件.这里提供一个touch指令. ngTouch.js "use strict"; angular.module("ngTouch&qu ...

  9. work flow

  10. sql server中的 SET NOCOUNT ON 的含义

    每次我们在使用查询分析器调试SQL语句的时候,通常会看到一些信息,提醒我们当前有多少个行受到了影响,这是些什么信息?在我们调用的时候这些信息有用吗?是否可以关闭呢? 答案是这些信息在我们的客户端的应用 ...