JDBC基础(三)(本文章来自www.cnjsp.org,未经作者本人同意,拒绝转载) |
发布日期:2004-12-28 |
作者:axman |
阅读人次:7087 |
|
关于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高级应用中介绍. |
|
整理发布:独孤求胜 |
摘自:www.cnjsp.org |
相关链接:http://www.cnjbb.org/thread.jsp?boardid=23&threadid=23068 |
文章回复:
Re:JDBC基础(三)(本文章来自www.cnjsp.org,未经作者本人同意,拒绝转载)
作者:JSAPLI 发表于:2005-06-25 15:31
通过Email跟作者联系
写的不错,能否举个完整的有关JSP调用SQLSERVER存储过程的例子。
这在网上较少。
Re:JDBC基础(三)(本文章来自www.cnjsp.org,未经作者本人同意,拒绝转载)
作者:王凯 发表于:2005-01-16 11:47
通过Email跟作者联系
您好,我是一名菜鸟,刚开始学JSP,您写的东西说实话我看不懂(真不好意思,我实在太菜了),我最近碰到一个问题我用JDBC和ODBC桥加载了数据库,为什么JSP页面可以向数据库写入数据而不可以读取数据?
如果您看到我的问题请速与我联系,写信或用QQ:66009741告诉我都行,谢谢了!