- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1. JDBC原理1.1. JDBC标准1.1.1. JDBC是什么Java Database Connectivity:Java访问数据库的解决方案。JDBC是Java应用程序访问数据库的里程碑式解决方案。Java研发者希望用相同的方式访问不同的数据库,以实现与具体数据库无关的Java操作界面。JDBC定义了一套标准接口,即访问数据库的通用API,不同的数据库厂商根据各自数据库的特点去实现这些接口。图-1应用、JDBC和数据库的关系1.1.2. JDBC接口及数据库厂商实现JDBC中定义了一些接口:1、驱动管理:DriverManager2、连接接口ConnectionDatabasemetaData3、语句对象接口StatementPreparedStatementCallableStatement4、结果集接口ResultSetResultSetMetaData1.1.3. JDBC工作原理JDBC只定义接口,具体实现由各个数据库厂商负责。程序员使用时只需要调用接口,实际调用的是底层数据库厂商的实现部分。图-2 通过JDBC访问数据库的过程JDBC访问数据库的工作过程:加载驱动,建立连接创建语句对象执行SQL语句处理结果集关闭连接1.1.4. Driver接口及驱动类加载要使用JDBC接口,需要先将对应数据库的实现部分(驱动)加载进来。驱动类加载方式(Oracle):Class.forName(oracle.jdbc.driver.OracleDriver);这条语句的含义是:装载驱动类,驱动类通过static块实现在DriverManager中的“自动注册”。1.1.5. Connection接口Connection接口负责应用程序对数据库的连接,在加载驱动之后,使用url、username、password三个参数,创建到具体数据库的连接。Class.forName(oracle.jdbc.OracleDriver)//根据url连接参数,找到与之匹配的Driver对象,调用其方法获取连接Connection conn = DriverManager.getConnection(jdbc:oracle:thin:@192.168.0.26:1521:tarena,openlab,open123);需要注意的是:Connection只是接口,真正的实现是由数据库厂商提供的驱动包完成的。1.1.6. Statement接口Statement接口用来处理发送到数据库的SQL语句对象,通过Connection对象创建。主要有三个常用方法:Statement stmt=conn.createStatement();//1.execute方法,如果执行的sql是查询语句且有结果集则返回true,如果是非查询语句或者没有结果集,返回falseboolean flag = stmt.execute(sql);//2.执行查询语句,返回结果集ResultSetrs = stmt.executeQuery(sql);//3.执行DML语句,返回影响的记录数int flag = stmt.executeUpdate(sql);1.1.7. ResultSet接口执行查询SQL语句后返回的结果集,由ResultSet接口接收。常用处理方式:遍历 / 判断是否有结果(登录)。String sql = select * from emp;ResultSetrs = stmt.executeQuery(sql);while (rs.next()) {?System.out.println(rs.getInt(empno)+,“ +rs.getString(ename) );}查询的结果存放在ResultSet对象的一系列行中,指针的最初位置在行首,使用next()方法用来在行间移动,getXXX()方法用来取得字段的内容。1.2. 数据库厂商实现1.2.1. Oracle实现在Java程序中访问不同数据库,需要下载对应数据库的驱动。Oracle数据库提供的驱动为ojdbc6.jar或者ojdbc14.jar,在开发时需要将驱动类加载到项目中,通过设置MyEclipse的Build Path选项。使用时就可以如下方式加载驱动类了:Class.forName(oracle.jdbc.driver.OracleDriver);1.2.2. MySQL实现MySQL对应的数据库驱动名为mysql-connector-java-5.0.4-bin.jar(不同版本可能有不同名称),将驱动类加载到项目中同样通过设置MyEclipse的Build Path选项。加载驱动类的方式:Class.forName(com.mysql.jdbc.Driver);2. J
您可能关注的文档
- 01-设计模式精解与案例分析高级版.doc
- 06226计算机辅助设计(二)复习思考题.doc
- 097dB58GHzCMOS全集成低噪声放大器设计.docx
- -再沸器介绍.doc
- 11-组合梁有限元分析.doc
- 12碳和碳的氧化物.doc
- 15分段制造检验.docx
- 15春福师《现代汉语(二)》在线作业一.doc
- 15春福师《教育原理》在线作业一.doc
- 15秋地大《多媒体计算机技术》在线作业一答案.doc
- 2025国家税务总局阿坝州税务局考调工作人员9人行测备考题库附答案.docx
- 2026中国光大银行北京分行秋季校园招聘备考题库附答案.docx
- 2025贵州安顺市市直机关面向全市遴选公务员50人行测备考题库附答案.docx
- 2025湖北浠水国创投资有限公司招聘15人模拟试卷附答案解析.docx
- 2026内蒙古气象部门招聘97名应届高校毕业生(气象类-第一批)备考题库附答案解析.docx
- 2026年中国邮政储蓄银行泰安分行校园招聘备考题库附答案解析.docx
- 2025重庆公路运输(集团)有限公司招聘55人考前自测高频考点模拟试题附答案解析.docx
- 2026年云南省思茅市单招职业适应性测试题库推荐.docx
- 备考2023年黑龙江省大兴安岭地区警察招考公安专业科目真题(含答案).pdf
- 2025江苏镇江市卫生健康委员会所属镇江市中西医结合医院遴选事业单位人员1人备考题库附答案解析.docx
最近下载
- 25秋国家开放大学《人文英语1》形考任务参考答案.docx
- 《小学家长进课堂》.pptx VIP
- 轮椅智能折叠机构设计与分析.doc VIP
- 考研真题 清华大学903生化分子和细胞生物学综合历年考研真题汇编(含部分答案).docx VIP
- [PPT]各类型桥梁各部位名称图解_136页_讲解详细_权威资料.pptx VIP
- 2025年全球咖啡产业链绿色可持续发展分析与市场趋势报告.docx
- 食品质量安全风险日管控、周排查、月调度检查记录表.docx VIP
- 人力资源招聘流程与面试评估模板人才选拔指南.doc VIP
- 《The Boxcar Children》棚车少年第1部.pdf VIP
- 2022年中国汉字听写大会汉字听写知识竞赛题库及答案(共十三套).pdf VIP
原创力文档


文档评论(0)