足球联赛管理系统开发.ppt
,Beyond Technology,Java技能实习(数据库部分),项目概述,项目名称:足球联赛管理系统开发 项目介绍:该项目用于对一个年度的足球联赛的各种信息进行管理,通过制作的专门界面,可以对球队、球员、比赛情况、各种统计信息进行管理。开发环境与开发工具:Java语言用Eclipse作为开发工具后台数据库采用SQL Server 2000系统结构C/S架构,项目开发步骤,项目的立项;项目的需求分析;数据库概念结构设计;数据库逻辑结构设计;数据库物理结构设计;项目的实施(编码);项目的测试;项目的维护与升级。,球队的管理:包括球队信息的添加、删除、修改和查询;球员的管理:包括球员信息的添加、删除、修改和查询;比赛过程的管理:包括一场比赛的基本信息的录入,如参赛双方的球队名称、比赛日期、比赛结果、进球情况等;积分榜查询:按照联赛的积分规则查询各个球队的名次;射手榜查询:按照进球多少查询进球队员的名次。,项目构思,项目设计,系统模块设计界面设计数据库设计,项目设计系统模块设计,项目设计界面设计,主窗体界面设计初始化数据库配置,项目设计界面设计,项目设计界面设计,主窗体界面设计主界面,项目设计界面设计,球队管理界面设计球队管理,项目设计界面设计,球队管理界面设计添加球队界面,项目设计界面设计,球队管理界面设计变更球队界面,项目设计界面设计,球队管理界面设计删除球队界面,项目设计界面设计,球队管理界面设计显示球队界面,球员管理界面设计球员管理,项目设计界面设计,球员管理界面设计添加球员,项目设计界面设计,球员管理界面设计根据姓名修改球员信息,项目设计界面设计,球员管理界面设计根据队名和球衣号码修改球员,项目设计界面设计,球员管理界面设计根据姓名删除球员,项目设计界面设计,球员管理界面设计根据队名和球衣号码删除球员,项目设计界面设计,球员管理界面设计查询球员,项目设计界面设计,比赛管理界面设计,项目设计界面设计,统计信息界面设计统计信息,项目设计界面设计,统计信息界面设计积分榜,项目设计界面设计,统计信息界面设计射手榜,项目设计界面设计,概念模型设计,项目设计数据库设计,逻辑模型设计球队表(Team),项目设计数据库设计,逻辑模型设计球员表(Member),项目设计数据库设计,逻辑模型设计比赛进程表(Course),项目设计数据库设计,逻辑模型设计进球表(Goal),项目设计数据库设计,逻辑模型设计积分榜(Score),项目设计数据库设计,逻辑模型设计射手榜(GoalScore),项目设计数据库设计,项目实施技术准备(JDBC技术),目前JDBC驱动程序共有四种类型:JDBC-ODBC桥,再加上ODBC驱动程序本机API,部分是Java的驱动程序面向数据库中间件的纯Java驱动程序直接面向数据库的纯Java驱动程序,项目实施技术准备(JDBC技术),采用JDBC-ODBC桥驱动程序,项目实施技术准备(JDBC技术),采用JDBC-ODBC桥驱动程序,项目实施技术准备(JDBC技术),采用JDBC-ODBC桥驱动程序,项目实施技术准备(JDBC技术),采用JDBC-ODBC桥驱动程序,项目实施技术准备(JDBC技术),采用JDBC-ODBC桥驱动程序,采用JDBC-ODBC桥驱动程序,项目实施技术准备(JDBC技术),采用微软提供的本机API JDBC驱动程序首先到微软官方网站下载JDBC驱动程序,解压缩后包括三个jar文件:msbase.jar、mssqlserver.jar、msutil.jar。将这三个jar文件添加到项目中或者添加到JDK的外部扩展包路径下。另外还要给SQL Server 2000安装SP3或以上的补丁程序。然后在Java代码中加载驱动程序时,url设置为“.SQLServerDriver”。,项目实施技术准备(JDBC技术),java.sql包中定义了一些常用的JDBC API:处理装载驱动程序,为创建新的数据库连接提供支持。完成连接某一指定的数据库的功能。在一个给定的连接中作为SQL执行声明的容器。控制对于给定声明取得结果列的途径。,项目实施技术准备(JDBC技术),采用JDBC操作数据库的基本步骤加载驱动程序建立数据库连接 生成语句对象利用语句对象中相应方法对数据库进行操作 关闭使用完的对象,项目实施技术准备(JDBC技术),随堂练习:在SQL Server 2000中创建一个名为MyTest的数据库,各种配置参数采用默认值,然后在其中创建一张名为table1的表,只包含一个整型字段abc。配置一个名为My的ODBC数据源,实现与第1题创建的MyTest数据库的连接。编写一段Java程序,实现通过第2题配置的ODBC数据源对table1表进行数据的增、删、改、查,并编译运行,查看结果是否正确。采用微软提供的JDBC驱动程序实现与第1题创建的MyTest数据库进行连接,并改写第3题的代码,实现通过JDBC驱动程序对table1表进行数据的增、删、改、查,并编译运行,查看结果是否正确。,项目实施技术准备(JDBC技术),项目实施技术准备(触发器),触发器是一种数据库对象,它可以自动执行,当用户的操作影响到触发器保护的数据时,触发器就会被触发自动执行所定义的SQL语句,激活触发器的动作称为触发器激活条件,触发器活动后所做的操作称为触发器动作。在触发器工作时,SQL Server 2000 会自动创建和管理两种特殊的表:deleted 表和 inserted 表。,创建触发器(P111-P115)当添加一支新球队时,要把这支球队的名称一并插入到积分榜中,这样能够保证球队表与积分榜中的球队保持一致,在对积分榜进行统计时,不会遗漏球队;当删除一支球队时,要在积分榜、比赛过程、球员表、射手榜等表中先把包含这支球队的所有记录都删除,否则会因为外码参照联系导致删除球队失败;,项目实施技术准备(触发器),创建触发器当修改球队时,要把积分榜、比赛过程、球员表、射手榜等表中与这支球队相关的所有记录都先做修改,否则也会因为外码参照联系导致修改球队失败;插入一场比赛详细信息时,将积分榜中的数据一起进行修改,并重新统计积分榜名次;插入进球信息时,将射手榜中的数据一起进行调整,并重新统计射手榜名次。,项目实施技术准备(触发器),在网上下载插件之后,解压缩,会得到两个文件夹:plugins和features,将它们复制到Eclipse目录下,覆盖原来的两个文件夹即可,这样就把该插件安装到Eclipse中了。,项目实施技术准备(Jigloo使用),项目实施,创建数据库创建表导入数据项目开发,项目实施创建数据库,在企业管理器中创建一个名为Football的数据库,其数据文件放在D盘分区某个指定的目录中,日志文件放在E盘分区某个指定的目录中(如果没有多个分区,也可以放在C盘分区的两个不同目录中)。数据库的其他属性保持默认值。,项目实施创建表,P121-P123,项目实施导入数据,选择数据源,项目实施导入数据,选择数据目的地,项目实施导入数据,指定表复制或查询,项目实施导入数据,指定数据源和目的地具体的表,项目实施导入数据,指定运行时间,项目实施导入数据,设置完成后的界面,项目实施导入数据,成功导入后的提示界面,项目实施导入数据,P129-P150,项目实施项目开发,项目实施项目改进,在架构方面,目前的项目采用的是C/S架构,以后可以考虑采用C/S、B/S混合架构,在管理端使用C/S架构对数据库中的数据进行增删改,在普通用户浏览查询端,可以采用B/S架构中的浏览器对数据进行浏览和查询,这样该系统可以扩展到互联网上使用;在功能方面,目前的模糊查询只能实现对单个关键字的模糊查询,今后可以改进为对多个关键字进行模糊查询;,在功能方面,还可以增加对进球方式(左脚、右脚、头球等)管理、助攻管理、换人(换上场时间、累计出场时间等)管理、红黄牌管理等;在用户体验方面,可以考虑在进行文本框输入时,输入过程中依据历史记录或者数据库中的数据不断对用户进行提示。例如数据库中有三支上海的球队,当在球队名称文本框中输入“上海”后,文本框下方自动出现一个下拉框,将三支上海的球队都提供出来,用户可以选择,也可以继续输入,当输入更多信息后,下拉框中的球队名称也会随着信息的进一步精确而逐渐减少。,项目实施项目改进,