数据库系统应用与开发实验二

上传人:876****10 文档编号:142096060 上传时间:2020-08-16 格式:DOC 页数:10 大小:364.50KB
返回 下载 相关 举报
数据库系统应用与开发实验二_第1页
第1页 / 共10页
数据库系统应用与开发实验二_第2页
第2页 / 共10页
数据库系统应用与开发实验二_第3页
第3页 / 共10页
数据库系统应用与开发实验二_第4页
第4页 / 共10页
数据库系统应用与开发实验二_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《数据库系统应用与开发实验二》由会员分享,可在线阅读,更多相关《数据库系统应用与开发实验二(10页珍藏版)》请在金锄头文库上搜索。

1、数据库系统应用与开发-实验二 作者: 日期:实验二 JDBC基础(1)一、相关知识点1、JDBC基本概念2、java连接数据库的方式3、JDBC简单查询二、实验目的:理解Java连接数据库的基本概念。理解JDBC的四种驱动程序,掌握纯java驱动和jdbc-odbc驱动。理解Statement对象和ResultSet对象。三、实验内容:1、 将booklib应用的JDBC驱动程序改成JDBC-ODBC驱动方式。第一步:设置ODBC数据源;第二步:修改DBUtil类中的相关代码;第三步:运行程序【实验结果与分析】A、 说明需要修改DBUtil类的哪些地方,及修改原因? private stati

2、c final String jdbcUrl=jdbc:odbc:cjeSQL;因为booklib应用的驱动方式是jdbc-odbc驱动2、 利用Statement对象和Result对象实现按出版社名称精确查询出版社功能(精确查询是指查询的目标和查询条件中值完全相同的数据)。第一步:在cn.edu.zucc.booklib.control. PublisherManager类中添加按出版社名称精确查询方法 public BeanPublisher loadPubByName(String name)throws BaseException第二步:编写上述方法,要求当相应名字的出版社不存在时,返

3、回null值;相关代码请参考提取所有出版社函数。第三步:启动booklib主程序,在出版社管理中录入几个出版社第四步:清空cn.edu.zucc.booklib.control. PublisherManager类中的main函数现有内容第五步:在main函数中编写代码,通过调用上面实现的方法按出版社名字查询出版社,如果返回null,则在控制台输出“没有找到出版社”,否则输出出版社编号。(注:控制台输出通过System.out.println()函数实现,函数调用的方法参考现有main函数中的内容)。要求main函数中调用两次上述函数,参数分别为一个确实存在的出版社,一个不存在的出版社。第六步

4、:以java application模式运行PublisherManager类,查看输出内容。【实验结果与分析】A、 请给出查询函数的代码。public List loadPubByName(String name)throws BaseExceptionList result=new ArrayList();Connection conn=null;try conn=DBUtil.getConnection();String sql=select pubid,publisherName,address from BeanPublisher where publisherName = name

5、;java.sql.Statement st=conn.createStatement();java.sql.ResultSet rs=st.executeQuery(sql);while(rs.next()BeanPublisher p=new BeanPublisher();p.setPubid(rs.getString(1);p.setPublisherName(rs.getString(2);p.setAddress(rs.getString(3);result.add(p); catch (SQLException e) e.printStackTrace();throw new D

6、bException(e);finallyif(conn!=null)try conn.close(); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();return result;B、 说明如何通过JDBC API判断没有查询到指定名字的出版社。 传递一个Driver给DriverManager,加载数据库驱动(通知jvm将驱动程序相关的类加载到内存中)。Class.forName() 通过URL得到一个Connection对象, 建立数据库连接DriverManager.getConne

7、ction(sDBUrl)DriverManager.getConnection(sDBUrl,sDBUserID,sDBPassword) 然后创建一个Statement对象(PreparedStatement或CallableStatement),用来查询或者修改数据库。Statement stmt=con.createStatement() 查询返回一个ResultSet。ResultSet rs=stmt.executeQuery(sSQL3、 利用Statement对象和Result对象实现按出版社名称模糊查询出版社功能(模糊查询是指查询的目标包含输入的条件)。第一步:在cn.edu

8、.zucc.booklib.control. PublisherManager类中添加按出版社名称精确查询方法 public List searchPubsByName(String name)throws BaseException第二步:编写上述方法,相关代码请参考提取所有出版社函数。第三步:清空cn.edu.zucc.booklib.control. PublisherManager类中的main函数现有内容第四步:在main函数中编写代码,通过调用上面实现的方法按出版社名字模糊查询出版社,并输出查询到的出版社信息。第六步:以java application模式运行PublisherMa

9、nager类,查看输出内容。【实验结果与分析】A、 请给出查询函数的代码。public List loadPubByName(String name)throws BaseExceptionList result=new ArrayList();Connection conn=null;try conn=DBUtil.getConnection();String sql=select pubid,publisherName,address from BeanPublisher where publisherName like %+name+%;java.sql.Statement st=con

10、n.createStatement();java.sql.ResultSet rs=st.executeQuery(sql);while(rs.next()BeanPublisher p=new BeanPublisher();p.setPubid(rs.getString(1);p.setPublisherName(rs.getString(2);p.setAddress(rs.getString(3);result.add(p); catch (SQLException e) e.printStackTrace();throw new DbException(e);finallyif(conn!=null)try conn.close(); catch (SQLException e) / TODO Auto-generated catch blocke.printStackTrace();return result;B、 比较精确查询和模糊查询方法,说明在SQL语句中的主要区别。精确查询必须是完全匹配才会输出,模糊只需部分匹配即可。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号