jdbc3个接口用来处理sql的执行,是Statement PreparedStatement CallableStatement 提供适当的Statement接口 批量执行sql 从数据库批量获取数据 PreparedStatement 比Statement性能要好 主要体现在一个sql语句多次重复执行的情况 PreparedStatemnt只编译解析一次而Statement每次编译一次. 批量修改数据库 Statement 提供了方法addBatch(String)和executeBatch() 调用方法为stmt.addBatch("isnert....."); stmt.addBatch("update.....") stmt.executeBatch(); 也可以用PreparedStatement从而更好的提高性能. pstmt=conn.preparedStatement("insert into test_table(......) values(....?)"); pstmt.setString(1,"aaa"); pstmt.addBatch(); pstmt.setString(1,"bbb"); pstmt.addBatch(); ..... pstmt.executeBatch(); 批量地从数据库中取数据. 通过setFetchSize()和getFectchSize()方法来设定和查看这个参数.这个参数对体统的性能影响比较大. 这个参数太小会严重地降低程序地性能. Connection Statement ResultSet都有这个参数,他们对性能地影响顺序是: ResultSet---------Statement---------Connection (4)优化ResultSet. 体现在以下几个方面 批量读取数据.合理设置ResultSet的getFetchSize()和setFetchSize()方法中的参数 使用正确的get和set方法 使用整数而不是字段名作为参数性能比较高, 例如 setInt(1,100); setString(2,"aaaa"); 比 setInt("id","100"); setString("name","aaaa"); 性能好 设置适当的滚动方向.有3个方向FETCH_FORWORD,FETCH_REVERSE FETCH_UNKNOWN 单向滚动性能比较高. 其他方面的性能优化 及时显示的关闭Connection Statement ResultSet 其中Connection可以用Connetion Pool处理. 使用数据库系统的强大查询功能去组织数据.这样程序运行是和数据库服务的交互次数少,数据库返回给 程序的记录条数少的多,所以性能有很大的提高. |
|