数据库模板实验报告_第1页
数据库模板实验报告_第2页
数据库模板实验报告_第3页
数据库模板实验报告_第4页
数据库模板实验报告_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

软件设计与体系结构实验报告课程名称软件设计与体系结构课程编号0920116实验项目名称数据库模板案例学号班级姓名专业学生所在学院指导教师实验室名称地点实验时间实验名称:数据库模板模式案例实验目的:数据库模板模式(ObserverPattern)是设计模式中行为模式的一种,它解决了上述具有一对多依赖关系的对象的重用问题。此模式的参与者分为两大类,一类是被观察的目标,另一类是观察该目标的观察者们。正因为该模式是基于“一对多”的关系,所以该模式一般是应用于由一个目标对象和N个观察者对象组成(当然也可以扩展为有多个目标对象,但我们现在只讨论前者)的场合。当目标对象的状态发生改变或做出某种行为时,正在观察该目标对象的观察者们将自动地、连锁地作出相应的响应行为。通过本次实验了解观察者模式的原理。并能够运用观察者模式来进行编程。实验内容1UML类图2程序的源代码importjava.io.FileInputStream;importjava.io.FileNotFoundException;importjava.io.IOException;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.sql.Statement;importjava.util.Properties;publicabstractclassJdbcAbstractTemplate{ privatePropertiesprops; //默认的资源文件的路径 privateStringproperties_Path="src/perties"; //构造函数初始化资源文件 publicJdbcAbstractTemplate(){ props=newProperties(); try{ props.load(newFileInputStream(properties_Path)); }catch(FileNotFoundExceptione){ e.printStackTrace(); }catch(IOExceptione){ e.printStackTrace(); } } //可以改变资源文件路径的构造函数 publicJdbcAbstractTemplate(Stringproperties_Path){ setProperties_Path(properties_Path); props=newProperties(); try{ props.load(newFileInputStream(properties_Path)); }catch(FileNotFoundExceptione){ e.printStackTrace(); }catch(IOExceptione){ e.printStackTrace(); } } publicStringgetProperties_Path(){ returnproperties_Path; } publicvoidsetProperties_Path(Stringproperties_Path){ perties_Path=properties_Path; } publicPropertiesgetProps(){ returnprops; } publicvoidsetProps(Propertiesprops){ ps=props; } publicfinalConnectiongetConnect(){ StringuseDB=props.getProperty("useDB"); useDB=useDB.toLowerCase(); StringDBDriver=props.getProperty(useDB+"_DBDriver"); Stringurl=props.getProperty(useDB+"_url"); StringdatabaseName=props.getProperty("databaseName"); url=url+databaseName; Stringusername=props.getProperty("username"); Stringpassword=props.getProperty("password"); try{ Class.forName(DBDriver); returnDriverManager.getConnection("jdbc:odbc:lidan"); }catch(Exceptione){ e.printStackTrace(); } returnnull; } publicfinalvoidclose(Statementst,Connectionconn){ try{ if(st!=null) st.close(); if(conn!=null) conn.close(); }catch(SQLExceptione){ e.printStackTrace(); } } publicfinalvoidclose(ResultSetrs,Statementst,Connectionconn){ try{ if(rs!=null) rs.close(); if(st!=null) st.close(); if(conn!=null) conn.close(); }catch(SQLExceptione){ e.printStackTrace(); } } publicbooleansave(Stringsql){ booleanflag=false; Connectionconn=null; Statementst=null; conn=getConnect(); try{ st=conn.createStatement(); if(st.executeUpdate(sql)>0) flag=true; }catch(SQLExceptione){ e.printStackTrace(); }finally{ close(st,conn); } returnflag; }}importjava.sql.Connection;importjava.sql.ResultSet;importjava.sql.SQLException;importjava.sql.Statement;publicclassJdbcTemplateTestextendsJdbcAbstractTemplate{ publicvoidselect(Stringsql){ Connectionconn=super.getConnect(); Statementst=null; ResultSetrs=null; try{ st=conn.createStatement(); rs=st.executeQuery(sql); while(rs.next()){ System.out.println(rs.getInt("编号")+"is"+rs.getString("用品")); } }catch(SQLExceptione){ e.printStackTrace(); } finally{ close(rs,st,conn); } } /** *@paramargs */ publicstaticvoidmain(String[]args){ JdbcTemplateTesttest=newJdbcTemplateTest(); test.select("select编号,用品fromobject"); }}#useDB\u4e3a\u6240\u4f7f\u7528\u7684\u6570\u636e\u5e93\u7c#databaseName\u683c\u5f0f\u5982\u4e0b\uff1a#sql2000:\u6570\u636e\u5e93\u540d;mysql:\u6570\u636e\u5e93\u540daccess:\u6570\u636e\u5e93\u6240\u5728\u8def\u5f84useDB=accessusername=password=databaseName=LunaGage#sqlserver2000databasesqlserver2000_DBDriver=com.microsoft.jdbc.sqlserver.SQLServerDriversqlserver2000_url=jdbc:sqlserver://localhost:1433;databaseName=#mysqldatabasemysql_DBDriver=com.mysql.jdbc.Drivermysql_url=jdbc:mysqlsql://localhost:3306/;#accessdatabaseaccess_DBDriver=sun.jdbc.odbc.JdbcOdbcDriveraccess_url=jdbc:odbc:3实验截图对该模式的认识经过本次数据库模板模式的实验,通过自己动手编代码,是自己理解观察者模式机制,并且知道数据库模板适用性模板方法应用与以下情况:1.一次性实现一个算法的不变部分,并将可变行为留给子类来实现。2.集中各个子类中的公共行为并将其置入一个公共类(本例中是超类)中,以避免代码重复。这是“代码重构”的一个经典实例。3.为控制子类扩展超类操作的方式,可定义在特定点调用“钩子”操作的模板

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论