无法使用JDBC连接进行计数

时间:2014-08-12 12:21:03

标签: java jdbc

我无法通过查询来获取行数。我已经使用了JDBC连接。但是,它没有显示任何错误,但它停止执行该过程。

这是我的代码

Transaction transaction=null;
    Connection c = null;
    Statement stmt = null;
    ResultSet result;
    try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager.getConnection(
         "jdbc:postgresql://192.168.1.7:5432/"+userDB,
     "postgres", "openerp");
     } catch (Exception e) {
         e.printStackTrace();
         System.err.println(e.getClass().getName() + ": " + e.getMessage());
         System.exit(0);
     }
    int count = 0;
    try {   
        LOGGER.info("In try of get");
        factory = HibernateUtil.connectDB(userDB);
        LOGGER.info("Connected to DB");
        //Open Session
        session = factory.openSession();
        //Begin Transaction
        transaction = session.beginTransaction();
        LOGGER.info("Beginning the transaction");
        stmt = c.createStatement();
        String sql = "SELECT COUNT(*) FROM mycontent_messages where status = '0'";

        count = stmt.executeUpdate(sql);
        LOGGER.info("successfully got count : "+count);
        c.commit();
        stmt.close();
        c.close();   

我得到的例外是

org.postgresql.util.PSQLException: A result was returned when none was expected.
at    org.postgresql.jdbc2.AbstractJdbc2Statement.executeUpdate(AbstractJdbc2Statement.java:307)
at net.vsspl.mycontent.daoimpl.contentImpl.getUnreadCount(contentImpl.java:379)
at net.vsspl.mycontent.services.countUnreadMessages.main(countUnreadMessages.java:49)

它记录到“开始交易”。之后它没有显示任何内容。我的代码中有任何问题吗?

3 个答案:

答案 0 :(得分:4)

您希望从查询中获取结果集并以此方式处理它,而不是获取受影响的行数。

ResultSet rs =  stmt.executeQuery(sql);
 int count = 0;
 if(rs.next())
 {
    count = rs.getInt(1);
  }

答案 1 :(得分:1)

  
    

count = stmt.executeUpdate(sql);

  

您没有执行更新;你正在执行一个查询。

答案 2 :(得分:0)

在这里,您正在执行查询以获取记录的计数,因此您应该使用

resultSet = stmt.executeQuery(sql);