版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、目目 录录 1 设计题目. .1 2 设计目的.2 3 设计分析 .3 4 概念结构设计 .6 5 逻辑结构设计 .11 6 表结构设计 .13 7 具体功能实现.15 8 总结.26 9 附录 . 27 1.1. 设计题目设计题目 学生成绩管理系统 2.2.设计目的设计目的 本学生成绩管理系统模块是为了实现学校人力资源的优化和学生成绩管 理的科学管理而设计的,通过试用本系统,可以更加有效的管理学生成绩信 息, 用数据库对大量数据的复杂操作进行保存,其中包括学生的基本信息,成绩 信息和班级成绩信息并且具有信息的增加,查询,修改和修改等功能。 3.3. 设计分析设计分析 3.1 可行性研究 (1
2、)利用面向对象的 java 语言来进行系统开发,可以很方便的根据实际 定义各个所需要的对象,并对这些对象进行操作。同时由于本系统是在用戶 图形界面进行各种用户操作,可以使界面多样化满足人们的对美观的要求, 更易懂、更方便操,能够更方便验证用户的输入是否正确,并进行相应的提 示,这些需求和功能在目前情况下利用所学知识完全可以实现。并且本系统 采用文件来存储数据,操作比较简单,方便学生成绩的导出与打印,省去了 人力的大量抄写,但是在一定程度上限制数据量和系统的运行速度。 该学生成绩管理系统可以在 microsoft windows xp 和 windows 7 系统 下进行开发和运行的,这些系统目
3、前已经比较普及,用户在该系统中可以方 便的进行各种操作,实现预期的目的。该系统的开发成本比较低,符合了人 们对低资源高效率的追求,利用较低的成本换取更高的回报。 (2)具体的定义问题: 此次开发的项目是一个学生成绩管理系统,进行学生信息的增删改查、学 生成绩的管理和班级成绩的管理,在进入系统之前需要登陆,登陆成功后即可 进入系统的相应的用户界面。 本系统的身份主要分为教务处、老师和学生。 若是教务处登录可以进行多条件查询学生的信息,也可以增加、删除、 修改、学生的信息,并可多条件查询学生成绩的信息,以及成绩的增加和修 改,查询班级成绩,可按班级查询或按日期查询。 若是老师登录,则可以查询所有的
4、学生信息、学生成绩和班级成绩。 若是学生登录,则只可以查询自己的信息和成绩,不可进行对任何信 息的任何修。 在登录界面有注册功能,并以学号为线索贯穿整个系统。 系统的基本流程图,如图 3.1 所示: 图 3.1 系统流程图 3.2 需求分析 (1) 用户需求:学生成绩管理系统的用户类,其属性有用户名密码以及 身份,用户必须登录成功后才可进入主界面,用户再实现学生信息的查询、 添加删除、修改,以及学生成绩的查询管理等功能,管理好这些用户对系统 安全有十分重要的影响。 (2) 功能需求: 登录模块:主要登录,系统自动根据用户的身份权限进行判断再弹出 不同的用户界面。 注册模块:此模块用于添加用户并
5、设定登录密码。 学生信息管理模块:使教务处实现对学生信息的添加、删除、修改、 查找,以及对外键密码的查询;教师和学生则只可以查看。 学生成绩管理模块:教务处可以实现对学生成绩添加、修改、查找学 生成绩可以进行学生成绩的操作;教师和学生只可以查看。 班级成绩管理模块:此模块主要是按条件查询功能,不能手动添加记 录,只能在添加学生成绩时,有系统自动调用方法对此表进行按班级并继承 此班级的成绩添加记录,如没有此班级的记录则不用继承任何数据此学生的 总成绩和平均成绩就是此条记录的总成绩和平均成绩。 4.4. 概念结构设计概念结构设计 学生成绩管理系统的设计,主要解决的是对系统中的学生的基本信息, 学生
6、成绩的基本信息,以及班级成绩管理工作。首先,需要定义各个所需要 的数据对象,然后在这些对象上进行操作;其次,实现功能模块时,采用先 模块化,后集成化,即对系统各个功能模块分别独立设计和调试,在创建系 统主登录界面时再将各个功能模块通过主菜单对各个模块的调用集成到一起, 最后进行系统整体设计调试。在数据存储和操作方面,采用文件的读写导出 数据库,并在读出数据之后放入链表进行操作;并在数据更新之后将数据存 到数据库中,这样可以减少对磁盘的直接操作次数,从而提高系统设计的效 率。 4.1 概念模型(系统 e-r 图) (1)局部 e-r 图 学生实体 e-r 图,如图 4.1 所示: 图 4.1 学
7、生实体图 登录用户(此实体图包括教务处、老师和学生)实体 e-r 图,如图 4.2 所示: 学生 学号姓名 班级 籍贯 民族 院系 入学年月出生年月 性别 教务处 用户名密码权限 图 4.2 登录用户实体图 学生成绩实体,如图 4.3 所示: 图 4.3 学生成绩实体图 班级实体 e-r 图,如图 4.4 所示: 图 4.4 班级实体图 (2)整体 e-r 图,如图 4.5 所示: 1n 11 n n 11 图 4.5 整体 e-r 图 这些类之间对于同一个学生来说,重复定义的数据是相同的,在功能调 用时采用数据耦合,降低系统中的耦合度。 学生成绩 学号姓名班级 院系 英语 java 操作系统
8、软件工程日期 平均成绩 总成绩 班级 班级号记录号 总成绩 总成绩日期 登录用户学生 学生成绩班级成绩 增删改查 增改查 添加 查询 4.2 类设计和数据存储 (1)类设计 用户类:首先定义一个用户类 logininfo,拥有私有属性用户名和密码, 实现用户的登陆,将数据存入数据库。 学生信息类:里面是一个学生信息类,包含学生姓名、学号、性别和 籍贯等一些基本信息。 学生成绩类:主要记录学生成绩信息。 班级成绩类:用来记录随学生成绩修改添加而随之添加的班级成绩记 录,并自动把班级成绩累加计算。 数据库连接类:主要实现与数据库的连接,实现数据的操作。 dao 包:主要是包含用户信息以、学生信息和
9、学生成绩信息的增删改查 的操作方法的一些类。 view 包:此包中主要实现用户界面,各种 gui 设计 主类:是程序的入口,程序从此类开始执行。 类中数据不可被其他类访问的数据权限设为 private,符合信息隐藏原理, 能更好的实现模块独立化。 (2)数据存储 数据存储主要是通过用 mysql 数据库来实现的,将数据库中的信息借 助 list 这个接口,通过接口回调得到一个 list 对象,将从文件中读取到的所有 对象都放到 list 对象中,然后通过对 list 进行遍历,实现增删改查操作。 学生成绩也可以导出到文本文档中保存,使用 bufferedwriter 类把 list 中的内容写
10、到文本文档中,使用 file 类实现文件的创建和选择。 4.3 功能模块设计 (1)登陆管理模块 实现用户的登录,如图 4.6 所示: 图 4.6 用户登录模块 (2)学生信息管理模块 实现对学生信息增加、删除、修改、查找功能。如图 4.7 所示: 图 4.7 学生信息管理模块 (3)学生成绩管理模块 用户可以实现对学生成绩的查询、添加和修改,其操作如下图 4.8 所示: 图 4.8 学生成绩管理模块 (4) 班级成绩管理模块 主要实现班级成绩的自动添加与统计,其操作如下图 4.9 所示 : 图 4.9 班级成绩管理模块 5.5. 逻辑结构设计逻辑结构设计 5.1 逻辑结构设计阶段的任务是将概
11、念结构设计阶段所得到的概念模型 转换为具体 dbms 所能支持的数据模型(即逻辑结构),并对其进行优化。 逻辑结构设计一般分为三步进行: (1) 从 e-r 图向关系模式转化数据库的逻辑设计主要是将概念模型转换 成一般的关系模式,也就是将 e-r 图中的实体、实体的属性和实体之间的联 系转化为关系模式。 (2) 将转化来的关系,网状、层次模型行向特定的 dbms 支持下的数据 模型转换。 (3)对数据模型进行优化。 5.2 概念结构(e-r 图)向逻辑结构的转换 (1)登录用户(用户 id,用户名,用户密码) (2)学生(学号,姓名,性别,院系,班级,籍贯,民族,入学年分,出生 年月) (3)
12、学生成绩(学号,姓名,班级,院系,英语成绩,操作系统成绩,软件 工程成绩,java 成绩,总成绩,平均成绩,日期) (4)班级成绩(班级号,总成绩,平均成绩,日期) 5.3 数据模型的优化 (1) 学生关系模式内部存在如下数据依赖: 用户 id 用户名 用户 id 用户名 (2) 学生关系模式内部存在如下数据依赖: 学号学生姓名 学号学生性别 学号学生院系 学号学生班级 学号学生籍贯 学号民族 学号入学年份 学号出生年月 (3) 学生成绩关系模式内部存在如下数据依赖: 学号学生姓名 学号学生班级 学号学生院系 学号英语成绩 学号操作系统成绩 学号软件工程成绩 学号java 成绩 学号总成绩 学
13、号平均成绩 学号日期 (4) 班级成绩关系模式内部存在如下数据依赖: 班级号总成绩 班级号平均成绩 班级号日期 由于本系统关系模式比较简单,并不需要进一步优化。这里需要说明的是 “用户”关系。用户的 id 是账号,实际上账号就是个实体的编号,如学生就 是学号,教师就是教师号。当俩个关系的码相同时,根据消除冗余数据的原则, 应该把这俩个关系合并为一个关系。即密码和权限应该放在学生、教师表中, 作为学生、教师实体的属性。但本系统中为了提高速度,方便管理,把账号、 用户名、密码和权限单提出来作为一张独立的表。 6.6. 表结构定义表结构定义 (1) 登录用户 t_login 表结构定义,如下图 6.
14、1 所示: 图 6.1 登录用户表结构定义图 (2) 学生 t_srudentinfo 表结构定义,如下图 6.2 所示: 图 6.2 学生表结构定义 (3)学生成绩 t_grade 表结构定义,如图 6.3 所示: 图 6.3 学生成绩表结构定义图 (4) 班级成绩 t_tongji 表结构定义,如图 6.4 所示: 图 6.4 班级成绩表结构定义图 7.7. 具体功能实现具体功能实现 7.1 登录功能的实现 (1) 登录界面该界面可以对用户名和密码进行验证如不正确则会显示错误 信息,如图 7.1 所示: 图 7.1 登录界面 (2)登录功能的实现代码,此段代码通过连接数据库用 sql 语句
15、查找符合 条件的用户,返回值为logininfo 类的对象,在调用此方法的程序中验证此对象是否 为空,如为空,则没有该用户显示错误信息;如不为空,则该用户存在,可直接用此对象 的 getrole()方法进入不同的界面。 publicpublic logininfo querybyusernameandpassword(logininfo user) logininfo u =newnew logininfo(); string name=user.getname(); string pwd=user.getpassword(); string sql=select * from t_login
16、 where name =+name+and password=+pwd+; dbconnection conn=newnew dbconnection(); resultset rs=conn.doquery(sql); trytry ifif(rs.next() u.setname(rs.getstring(name); u.setpassword(rs.getstring(password); u.setrole(rs.getint(role); catchcatch (sqlexception e) e.printstacktrace(); conn.queryclose(); ret
17、urnreturn u; 7.2 学生信息查询功能的实现 (1) 学生信息查询功能界面,可通过此界面按多条件查找如可按学号、姓 名或班级等查找,如图 7.2 所示: 图 7.2 学生信息查询界面 (2) 学生信息查询功能的实现代码,此代码利用 sql 语句在数据库中查找 所有学生信息,存放在 list 对象中;如有条件的查找则只需修改 sql 语句即可,提高了 代码的重用性。 publicpublic list queryall() dbconnection conn = newnew dbconnection(); string sql = select * from t_studentin
18、fo; resultset rs = conn.doquery(sql); list list = newnew arraylist(); trytry whilewhile (rs.next() studentinfo student = newnew studentinfo(); student.setid(rs.getint(id); student.setname(rs.getstring(name); student.setclasses(rs.getint(classes); student.setsex(rs.getstring(sex); student.setrace(rs.
19、getstring(race); student.setnativeplace(rs.getstring(nativeplace); student.setdepartment(rs.getstring(department); student.setschoolyear(rs.getstring(schoolyear); student.setbirth(rs.getstring(birth); list.add(student); catchcatch (sqlexception e) e.printstacktrace(); conn.queryclose(); returnreturn
20、 list; 7.3 学生信息添加功能的实现 (1) 学生信息添加功能界面,此界面可添加学生信息到数据库中,如图 7.3 所示: 图 7.3 学生信息添加界面 (2) 学生信息添加功能的实现代码,此方法以studentinfo 的对象为参数, 省去了传多个参数的麻烦,返回值为布尔型,可直接判断添加操作是否成功。 publicpublic booleanboolean insertstudent(studentinfo student) dbconnection conn = newnew dbconnection(); string name = student.getname(); inti
21、nt classes = student.getclasses(); string sex=student.getsex(); string race=student.getrace(); string nativeplace=student.getnativeplace(); string department=student.getname(); string schoolyear=student.getschoolyear(); string birth=student.getbirth(); string sql = insert into t_studentinfo (name,cl
22、asses,sex,race,nativeplace,department,schoolyear,birth) values(+ name + , + classes + , + sex + ,+race+,+nativeplace+,+department+,+schoolyear+,+b irth+); intint count = conn.update(sql); ifif (count 0) conn.updateclose(); returnreturn truetrue; elseelse conn.updateclose(); returnreturn falsefalse;
23、7.4 学生信息修改功能的实现 (1)学生信息修改功能界面,此界面可以修改学生信息,如图 7.4 所示: 图 7.4 学生信息修改界面 (2)学生信息修改功能的实现代码,此方法以studentinfo 的对象为参数,省去 了传多个参数的麻烦,返回值为布尔型,可直接判断修改操作是否成功。 publicpublic booleanboolean alteruser(studentinfo s) string name=s.getname(); intint classes=s.getclasses(); string sex=s.getsex(); string race=s.getrace();
24、 string nativeplace=s.getnativeplace(); string department=s.getdepartment(); string schoolyear=s.getschoolyear(); string birth=s.getbirth(); dbconnection conn=newnew dbconnection(); string sql=update t_studentinfo set name=+name+,classes=+classes+,sex=+sex+,race=+race+,nati veplace=+nativeplace+, +
25、department=+department+, schoolyear=+schoolyear+,birth=+birth+ where id=+s.getid(); intint count=conn.update(sql); ifif(count0) conn.updateclose(); returnreturn truetrue; elseelse conn.updateclose(); returnreturn falsefalse; 7.5 学生信息删除功能的实现 (1)学生信息删除功能界面,在查询的结果表上直接选中表中的行,点击 删除确定就可删除选中行如图 7.5 所示: 图 7
26、.5 学生信息删除界面 (2)学生信息删除功能的实现代码,此方法的参数(此参数是通过在表中添 加的鼠标监听器得到的)是所选的表中行的信息的学号,返回布尔型的值,可 判断删除是否成功。 public boolean deletebyid(int id) dbconnection conn=new dbconnection(); string sql=delete from t_studentinfo where id= + id; int count=conn.update(sql); if(count0) conn.updateclose(); return true; else conn.u
27、pdateclose(); return false; 7.6 学生成绩查询功能的实现 (1)学生成绩查询功能界面,可多条件查询学生成绩,如图 7.6 所示: 图 7.6 学生成绩查询功能界面 (2) 学生成绩查询功能的实现代码,此方法将查到的结果集中的属性放到 grade 对象的相应字段中(用 grade 类中的 get()方法实现),再用 while 循环 将 grade 对象放入到 list 中。 publicpublic list queryall() dbconnection conn = newnew dbconnection(); string sql = select * fr
28、om t_grade; resultset rs = conn.doquery(sql); list list = newnew arraylist(); trytry whilewhile (rs.next() grade grade = newnew grade(); grade.setid(rs.getint(id); grade.setname(rs.getstring(name); grade.setdepartment(rs.getstring(department); grade.setclasses(rs.getint(classes); grade.setenglish(rs
29、.getfloat(english); grade.setsoft(rs.getfloat(soft); grade.setos(rs.getfloat(os); grade.setjava(rs.getfloat(java); grade.setsum(rs.getfloat(sum); grade.setaverage(rs.getfloat(average); grade.setdates(rs.getstring(dates); list.add(grade); catchcatch (sqlexception e) e.printstacktrace(); conn.queryclo
30、se(); returnreturn list; 7.7 学生成绩添加功能的实现 (1)学生成绩添加功能界面,此界面可以添加学生成绩,如图 7.7 所示: 图7.7 学生成绩添加界面 (2) 学生成绩添加功能的实现代码,传 grade 对象参数,返回布尔值,方 便判断。 publicpublic booleanboolean insertgrade(grade grade) dbconnection conn = newnew dbconnection(); string name = grade.getname(); string department=grade.getdepartment
31、(); intint classes =grade.getclasses(); floatfloat english=grade.getenglish(); floatfloat soft=grade.getsoft(); floatfloat os=grade.getos(); floatfloat java=grade.getjava(); floatfloat sum=grade.getsum(); floatfloat average=grade.getaverage(); string dates=grade.getdates(); string sql = insert into
32、t_grade(name,department,classes,english,soft,os,java,sum,average,dates) values(+ name + ,+department+, + classes + , +english + ,+soft+,+os+,+java+,+sum+,+average+,+dates+); intint count = conn.update(sql); ifif (count 0) conn.updateclose(); returnreturn truetrue; elseelse conn.updateclose(); return
33、return falsefalse; 7.8 学生成绩修改功能的实现 (1)学生成绩修改功能界面,此界面只可以更改分数不可以更改其他信息, 这样避免了对学生信息更改的混乱,如图 7.8 所示: 图 7.8 学生成绩修改界面 (2) 学生成绩修改功能的实现代码,此方法运用的技术同添加方法相同。 publicpublic booleanboolean altergrade(grade g) floatfloat english=g.getenglish(); floatfloat soft=g.getsoft(); floatfloat os=g.getos(); floatfloat java=
34、g.getjava(); floatfloat sum=english+soft+os+java; floatfloat average=sum/4; dbconnection conn=newnew dbconnection(); string sql=update t_grade set english=+english+,soft=+soft+,os=+os+,java=+java+,sum=+sum+,a verage=+average+ where id=+g.getid(); intint count=conn.update(sql); ifif(count0) conn.upda
35、teclose(); returnreturn truetrue; elseelse conn.updateclose(); returnreturn falsefalse; 7.9 学生成绩导出功能的实现 (1)学生成绩导出功能界面,此界面可以再选位置创建一个新的文本文档, 将表中的内容存放到此 文本文档中,如图 7.9 所示: 图 7.9 学生成绩导出功能界面 (2) 学生成绩导出功能的实现代码,此段代码运用了 file 类和 bufferedwtiter 类来实现文件的创建与写出(从内存写到外存)。 gradedao data=new gradedao(); list list=data
36、.queryall(); gradetable table=new gradetable(); jtable table1=new jtable(); table1=table.gradetable(table1, list); int p=filedialog.showsavedialog(this); file file=filedialog.getselectedfile(); string s= 学号 + 姓名 + 院系 + 班级 + 英 语 + 软件工程 + 操纵系统 + java + 总成绩 + 平均成绩 + 日期 +n ; try filewriter write=new fil
37、ewriter(file); bufferedwriter write1=new bufferedwriter(write); /从内存写 出到硬盘 write1.write(s); write1.newline(); for(int i=0;ilist.size();i+) grade g=new grade(); g=(grade) list.get(i); string s1 = +g.getid()+ +g.getname()+ +g.getdepartment()+ +g.getclasses()+ +g.getenglish()+ +g.getsoft()+ +g.getos()+
38、 +g.getjava()+ +g.getsum()+ +g.getaverage()+ +g.getdates()+ n; system.out.println(s1); /从内存写出到硬盘 write1.write(s1); write1.newline(); write1.close(); write.close(); catch(ioexception a) 7.10 班级成绩查询功能的实现 (1)班级成绩查询功能界面,此界面可以多条件查询班级成绩,如图 7.10 所示: 图 7.10 班级成绩查询界面 (2)班级成绩查询功能的实现代码,此方法将查到的结果集中的属性放到 tongji
39、对象的相应字段中(用 tongji 类中的 get()方法实现),再用 while 循 环将 tongji 对象放入到 list 中,运用 list 对象更方便操作。 publicpublic list queryall() dbconnection conn = newnew dbconnection(); string sql = select * from t_tongji; resultset rs = conn.doquery(sql); list list = newnew arraylist(); trytry whilewhile (rs.next() tongji t = n
40、ewnew tongji(); t.setid(rs.getint(id); t.setclasses(rs.getint(classes); t.setsum(rs.getfloat(sum); t.setaverage(rs.getfloat(average); t.setdates(rs.getstring(dates); list.add(t); catchcatch (sqlexception e) e.printstacktrace(); conn.queryclose(); returnreturn list; 8.8. 总结总结 经过四个多星期的系统设计与代码编写,基本完成了学
41、生成绩管理系统 (主要是权限分配、学生信息管理、学生成绩管理、班级成绩管理)的设计与 实现。在这个系统中,可实现由计算机代替人工执行一系列诸如学生信息、学 生成绩和班级成绩信息的增、删、查、改和导出等操作以及个人信息的更新等 等,这样就使管理人员从繁重的工作中解脱出来,同时实现管理工作的规范化、 效率化、国际化。 在设计过程中,我首先考虑到了本系统各个大的功能模块,然后进行更加 详细的划分,逐步完善各个模块的具体内容。在进行具体代码的编写时,突然 会发现有很多边界条件没有考虑到,各种各样的漏洞导致系统容易崩溃不能正 常运行,这就需要补充很多的边界控制条件,这时才明白写出能运行的程序和 写出健壮
42、的程序是完全不同的两个概念,这些都是需要牢记和掌握的。在信息 提示方面,需要给用户一些温馨的提示,而不是诸如“错误编号 0 x704820”这 类的冰冷警告。我们要让用户对系统感到亲切和易使用,并能通过温馨提示让 用户自己解决问题,这也可以减少维护人员的工作量,我们需要的就是一个健 壮、友好的系统。 9.9. 附录附录 (1)bean 包 /*bean 包中的 logininfo 类*/ package bean; public class logininfo int id; string name; string password; int role; public int getid()
43、return id; public void setid(int id) this.id = id; public string getname() return name; public void setname(string name) = name; public string getpassword() return password; public void setpassword(string password) this.password = password; public int getrole() return role; public void set
44、role(int role) this.role = role; /*bean 包中的studentinfo 类*/ package bean; public class studentinfo private int id; private string name; private int classes; private string sex; private string race; private string nativeplace; private string department; private string schoolyear; private string birth;
45、 public int getid() return id; public void setid(int id) this.id = id; public string getname() return name; public void setname(string name) = name; public int getclasses() return classes; public void setclasses(int classes) this.classes = classes; public string getsex() return sex; public
46、 void setsex(string sex) this.sex = sex; public string getrace() return race; public void setrace(string race) this.race = race; public string getnativeplace() return nativeplace; public void setnativeplace(string nativeplace) this.nativeplace = nativeplace; public string getdepartment() return depa
47、rtment; public void setdepartment(string department) this.department = department; public string getschoolyear() return schoolyear; public void setschoolyear(string schoolyear) this.schoolyear = schoolyear; public string getbirth() return birth; public void setbirth(string birth) this.birth = birth;
48、 /*bean 包中的grade 类*/ package bean; public class grade private int id; private string name; private int classes; private string department; private float english; private float soft; private float os; private float java; private float sum; private float average; private string dates; public string ge
49、tdepartment() return department; public void setdepartment(string department) this.department = department; public int getid() return id; public void setid(int id) this.id = id; public string getname() return name; public void setname(string name) = name; public int getclasses() return cla
50、sses; public void setclasses(int classes) this.classes = classes; public float getenglish() return english; public void setenglish(float english) english = english; public float getsoft() return soft; public void setsoft(float soft) this.soft = soft; public float getos() return os; public void setos
51、(float os) this.os = os; public float getjava() return java; public void setjava(float java) java = java; public float getsum() return sum; public void setsum(float sum) this.sum = sum; public float getaverage() return average; public void setaverage(float average) this.average = average; public str
52、ing getdates() return dates; public void setdates(string dates) this.dates = dates; /*bean 包中的tongji 类*/ package bean; public class tongji private int id; private int classes; private float sum; private float average; private string dates; public int getid() return id; public void setid(int id) this
53、.id = id; public int getclasses() return classes; public void setclasses(int classes) this.classes = classes; public float getsum() return sum; public void setsum(float sum) this.sum = sum; public float getaverage() return average; public void setaverage(float average) this.average = average; public
54、 string getdates() return dates; public void setdates(string datesl) this.dates = dates; (2)jdbc包 /* jdbc包中的dbconnection 类*/ package jdbc; import java.sql.connection; import java.sql.drivermanager; import java.sql.resultset; import java.sql.sqlexception; import java.sql.statement; public class dbcon
55、nection private resultset rs; private connection con; private statement st; static try class.forname(com.mysql.jdbc.driver); /加载驱动 catch (classnotfoundexception e) e.printstacktrace(); public void getconnection() try con=drivermanager.getconnection(jdbc:mysql:/localhost:3306/student,roo t,root); /连接
56、数据库语句 catch (sqlexception e) e.printstacktrace(); /*查询数据库*/ public resultset doquery(string sql) this.getconnection(); try st=con.createstatement(); / 用连接创建sql执行语句 rs=st.executequery(sql); / 用sql的执行语句调用executequery返回结果 集对象 catch (sqlexception e) e.printstacktrace(); return rs; /*关闭数据库连接*/ public void queryclose() try rs.close(); st.close(); con.close(); catch (sqlexception e) e.printstacktrace(); /*更新数据库,返回的本次操作影响的数据库的行数*/ public int update(string sql) this.getconnection(); int count=0; try st=con.createstatement(); count=st.executeupdate(sql); catch (sqlexc
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度景观石石材行业合作发展合同3篇
- 餐具行业安全生产工作总结
- 零售行业顾问工作总结提高零售店销售额
- 土地使用权赠与合同(2篇)
- 浙江财经大学东方学院《离散数学与数据结构》2023-2024学年第一学期期末试卷
- 二零二五年度建筑工程施工合同中建筑材料质量监管3篇
- 榆林能源科技职业学院《微积分上》2023-2024学年第一学期期末试卷
- 浙江工业职业技术学院《最优化理论与算法》2023-2024学年第一学期期末试卷
- 2024年美容师招聘固定期限协议版B版
- 二零二五年度家教服务合同与隐私保护条款3篇
- 2024年东方航天港海阳产业园开发有限公司招聘笔试参考题库含答案解析
- 福建省泉州市2022-2023学年高一年级上册期末教学质量监测英语试卷(含答案)
- 继承传统文化弘扬中国精神
- 高考体育特长生培训
- 三年级下册口算天天100题(A4打印版)
- 广东省肇庆市2024届高三第二次教学质量检测数学试题(解析版)
- 部门预算编制培训课件
- 采购缺乏计划性的整改措施
- 《阀门安装一般规定》课件
- 边缘计算应用
- 江苏省建筑节能分部工程施工方案范本
评论
0/150
提交评论