ResultSet.last()和ResultSet.beforeFirst()以及ResultSet..getRow()

要使用resultset的这个方法,首先在得到这个resultset的时候必须把statement声明成为scrollable,例如:
PreparedStatement stmt = connection.prepareStatement(sql, para1, para2);
其中para1和para2可以使用ResultSet类中的常量。

你在创建Statement的时候必须指定允许以后移动:
PreparedStatement stmt = connection.prepareStatement(sql,
ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY );

Statement = Connection.createStatement(int resultSetType,int resultSetConcurrency)
resultSetType(结果集类型)包括:

ResultSet.TYPE_FORWARD_ONLY  缺省类型。该常量指示光标只能向前移动的 ResultSet 对象的类型。

ResultSet.TYPE_SCROLL_INSENSITIVE 该常量指示可滚动但通常不受 ResultSet 底层数据更改影响的 ResultSet 对象的类型。

ResultSet.TYPE_SCROLL_SENSITIVE 该常量指示可滚动并且通常受 ResultSet 底层数据更改影响的ResultSet 对象的类型。

resultSetConcurrency(并发类型)包括:
ResultSet.CONCUR_READ_ONLY 缺省类型。该常量指示不可以更新的 ResultSet 对象的并发模式。
ResultSet.CONCUR_UPDATABLE 该常量指示可以更新的 ResultSet 对象的并发模式。

不需要执行select count(*) from table,对表数据进行查询
ResultSet.last():方法将游标指向结果集末尾
ResultSet..getRow():返回结果是当前数据集的行号,而不是结果的行数
ResultSet.beforeFirst():将游标移到第一行前

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
// 先连接数据库 Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/javaweb?useUnicode=true&characterEncoding=UTF-8"; String username="root"; String password=""; Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/environment?charaterEncoding=utf-8","root","123456"); request.setCharacterEncoding("UTF-8");//设置字符编码,避免出现乱码 double time1 = Double.parseDouble(request.getParameter("time1")); double time2 = Double.parseDouble(request.getParameter("time2")); String sql = "select * from cx where time>=? and time<=?"; PreparedStatement preparedStatement = conn.prepareStatement(sql); preparedStatement.setDouble(1,time1); preparedStatement.setDouble(2,time2); ResultSet resultSet = preparedStatement.executeQuery();//执行sql语句用来返回单个 ResultSet 对象 resultSet.last();//移动到最后一条记录 %> <center> 在此段时间内共有 <font size="5" color="red"><%=resultSet.getRow()%></font>条记录 <table border="2" bgcolor="rgba(216, 191, 216, 0.5)" width="650"> <tr> <td>温度</td> <td>湿度</td> <td>光照</td> <td>时间</td> </tr> <% resultSet.beforeFirst(); while (resultSet.next()){ %> <tr align="center"> <td><%=resultSet.getString("temperature")%></td> <td><%=resultSet.getString("humidity")%></td> <td><%=resultSet.getString("guangzhao")%></td> <td><%=resultSet.getString("time")%></td> </tr> <%}%> </table> </center> <% if (resultSet!=null){ resultSet.close(); } if (preparedStatement!=null){ preparedStatement.close(); } if (conn!=null){ conn.close(); } %> 找出这段代码的错误
05-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值