`
wind_bell
  • 浏览: 291965 次
  • 性别: Icon_minigender_2
  • 来自: 广州
社区版块
存档分类
最新评论

JDBC基础(三)注:转

    博客分类:
  • JDBC
阅读更多

关于Statement对象:
    前面说过,Statement对象是用来绑定要执行的操作的,在它上面有三种执行方法:
即用来执行查询操作的executeQuery(),用来执行更新操作的executeUpdate()和用来执行
动态的未知的操作的execute().
    JDBC在编译时并不对要执行的SQL语句检测,只是把它看着一个String,只有在驱动
程序执行SQL语句时才知道正确与否.
    一个Statement对象默认同时只能有一个结果集在活动.这是宽容性的,就是说即使没有
调用ResultSet的close()方法,只要打开第二个结果集就隐含着对上一个结果集的关闭.所以
如果你想同时对多个结果集操作,就要创建多个Statement对象,如果不需要同时操作,那么可
以在一个Statement对象上顺序操作多个结果集.(不过当我修改这篇文章的时候已经可以同时

保持多个结果集了)
    
    这里我不得不特别说明一下,很多人会用一个Statement进行嵌套查询,然后就来问
我说为什么不能循环?道理上面已经说清楚了.我们来详细分析一下嵌套查询:
    Connection conn = null;
    Statement stmt = null;
    conn = .......;
    stmt = conm.createStatement(xxxxxx);
    ResultSet rs = stmt.executeQuery(sql1);
    while(rs.next()){
        str = rs.getString(xxxxx);
        ResultSet rs1 = stmt.executeQuery("select * from 表 where 字段=str");
    }
当stmt.executeQuery("select * from 表 where 字段=str");赋给rs1时,这时隐含的操作
是已经关闭了rs,你还能循环下去吗?
所以如果要同时操作多个结果集一定要让它他绑定到不同的Statement对象上.好在一个connection
对象可以创建任意多个Statement对象,而不需要你重新获取连结.

    关于获取和设置Statement的选项:只要看看它的getXXX方法和setXXX方法就明白了,这儿
作为基础知识只提一下以下几个:
    setQueryTimeout,设置一个SQL执行的超时限制.
    setMaxRows,设置结果集能容纳的行数.
    setEscapeProcessing,如果参数为true,则驱动程序在把SQL语句发给数据库前进行转义替
换,否则让数据库自己处理,当然这些默认值都可以通过get方法查询.

    Statement的两个子类:
    PreparedStatement:对于同一条语句的多次执行,Statement每次都要把SQL语句发送给数据
库,这样做效率明显不高,而如果数据库支持预编译,PreparedStatement可以先把要执行的语句一次发
给它,然后每次执行而不必发送相同的语句,效率当然提高,当然如果数据库不支持预编译,
PreparedStatement会象Statement一样工作,只是效率不高而不需要用户工手干预.
    另外PreparedStatement还支持接收参数.在预编译后只要传输不同的参数就可以执行,大大
提高了性能.
        
    PreparedStatement ps = conn.prepareStatement("select * from 表 where 字段=?");
    ps.setString(1,参数);
    ResultSet rs = ps.executeQuery();
    
    CallableStatement:是PreparedStatement的子类,它只是用来执行存储过程的.
    CallableStatement sc = conn.prepareCall("{call query()}");
    ResultSet rs = cs.executeQuery();
    
    关于更高级的知识我们在JDBC高级应用中介绍.  

分享到:
评论

相关推荐

    (彭涛注非常好的资料)跟姐姐学JDBC.rar

    但理解和掌握JDBC基础知识仍然是每个Java开发者的必备技能,因为它有助于理解这些框架的工作原理,并在遇到问题时能进行底层排查。 通过《跟姐姐学JDBC》这份资料,你可以系统地学习JDBC的各个方面,结合实际案例...

    shopping-management-system_超市管理系统_

    商品信息的管理是超市运营的基础,确保了数据的准确性和实时性。 2. 库存控制:系统应具备库存监控功能,实时更新商品库存,当库存量低于预设阈值时,能发出预警,以便及时补充货品。同时,它还能记录每一次出入库...

    how2j离线免费版.rar

    8. **数据库操作**:涉及JDBC基础,事务管理,以及与MySQL、Oracle等常见数据库的交互。 9. **Maven或Gradle**:如何使用构建工具管理项目依赖。 10. **Web开发**:讲解Servlet、JSP、过滤器和监听器,以及SpringMVC...

    Java工资管理系统

    这个系统集成了基础的数据存储、检索、更新以及删除等操作,旨在提高人力资源部门的效率,同时提供了一个直观的用户界面,方便操作人员进行日常的工资管理。 在Java工资管理系统中,主要涉及以下几个核心知识点: ...

    基于SpringBoot开发的长途汽车售票系统源码+sql数据库+项目说明+设计报告.zip

    配置属性文件路径:src/main/resources/application.properties 注:只需配置和修改sql主机地址,数据库名,用户名,密码, 项目访问路径,这几个属性,项目即可正常运行访问。 # DataSource jdbc.driver=...

    Web原理及应用:微博—会员管理

    一般会使用关系型数据库如MySQL,通过JDBC或ORM框架(如Hibernate或MyBatis)来与数据库交互。在添加会员时,会执行SQL的INSERT语句。同样,删除会员会执行DELETE语句,而展示会员信息则会使用SELECT语句。 为了...

    基于Servlet JSP MySQL的用户注册模块V1.0

    在这个过程中,涉及到的关键技术包括Servlet、JSP和JDBC。 Servlet是Java编程语言中用于扩展服务器功能的接口,它处理来自客户端(如浏览器)的请求,并生成响应。在这个用户注册模块中,Servlet作为服务器端的控制...

    was部署与配置手册

    - **启动命令**:`D:\IBM\WebSphere\AppServer\bin>startServer.bat server1` (注:server1 是默认服务器名,可根据实际情况调整) - **停止命令**:`D:\IBM\WebSphere\AppServer\bin>stopServer.bat server1` #####...

    图书管理系统

    接着,配置数据库连接,通常会使用JDBC驱动程序,通过DSN(数据源名称)或连接字符串建立与SQL Server的连接。最后,启动Tomcat,用户就可以通过浏览器访问图书管理系统了。 总的来说,《图书管理系统》是IT行业中...

    基于ssm+bootstrap的简单员工管理系统 +源代码+文档说明

    注:使用前需要配置maven环境 使用中遇到问题可提交issue,+qq讨论 使用工具eclipse,在eclipse导入文件即可使用 通过运行项目里面的ssm_crud.sql来导入数据库结构 注意修改数据库信息:ssm-crud/src/main/...

    java版飞机大战源码-Rockira.github.io:Rockira.github.io

    注 : 没链接的是还没写 :hot_beverage: 各类知识点总结 下面的文章都有对应的原创精美PDF,在持续更新中,可以来找我催更~ Hibernate AJAX Redis ...... :hot_beverage:Java基础 计算机操作系统与Linux 计算机网络 7...

    PL/SQL 基础.doc

    PL/SQL 基础,一个不错的 PL/SQL 参考手册。内容预览: ---- 第一章 PL/SQL 简介 ---- 1. Oracle应用编辑方法概览 ... 注:a. 加上REVERSE关键字 表示递减,从结束边界到起始边界,递减步长为一; ...

    Eclipse连接MySQL数据库宣贯.pdf

    // (注:示例代码中这部分未完整给出) } catch (Exception e) { e.printStackTrace(); } finally { if (sm != null) { try { sm.close(); } catch (SQLException e) { e.printStackTrace(); } } if ...

    jsp资料,非常好的基础学习资料

    JSP的执行过程包括翻译、编译和执行三个阶段。 2. **JSP基本结构**:一个JSP页面由两部分组成——静态内容(HTML、CSS、JavaScript)和动态脚本元素(Java代码)。JSP的动态部分可以包含脚本元素(Scriptlets)、...

    自己总结的Kettle使用方法和成果.doc

    Kettle 中有两种脚本文件,transformation 和 job,transformation 完成针对数据的基础转换,job 则完成整个工作流的控制。 三、Kettle 的安装和配置 首先,需要下载开源免费的 pdi-ce 软件压缩包,当前最新版本为...

    Spring+SpringMVC+MyBatis SSM

    本程序适合初学者学习,采用Spring+SpringMVC+...注:本程序绝对100%可以使用,仅用于学习交流,一切从事商业活动与本作者无关,保留一切解释权。 代码简单,易懂,欢迎共同学习交流QQ:596085859 本代码出持续升级。

    jsp编程光盘,详细的源代码例程及注释,从初级到高级,具参考价值!

    JSP最终会被翻译成Servlet,它们都是基于Java的Web开发技术,但JSP更注重视图层,Servlet则更适合控制逻辑。 **五、JSP示例代码** 压缩包中的例程可能包括以下类型: 1. **Hello, World!**:基础的JSP页面展示,...

    基于JSP的公司办公信息管理系统设计与实现毕业设计(源代码+项目报告).zip

    7. **数据库连接**:在公司办公信息管理系统中,可能涉及到数据库操作,如使用JDBC(Java Database Connectivity)进行数据存取,或者使用ORM框架如Hibernate或MyBatis简化数据库操作。 8. **安全性**:考虑到办公...

    基于SpringMVC+Spring+Hibernate+JQuery+Bootstrap框架的OA系统

    注:建库时,字符集编码为:utf8(utf8_general_ci) ---修改配置文件“jdbc.properties”,改成对应数据库的用户名和密码 ---“sysconfig.properties”系统配置文件;需要修改“root.dir”属性,设置为...

    基于SpringMvc+Spring+MyBatis的OA系统项目

    注:建库时,字符集编码为:utf8(utf8_general_ci) ---修改配置文件“jdbc.properties”,改成对应数据库的用户名和密码 ---“sysconfig.properties”系统配置文件;需要修改“root.dir”属性,设置为...

Global site tag (gtag.js) - Google Analytics