让java从Mysql返回多个ResultSet

Posted 不如来编码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了让java从Mysql返回多个ResultSet相关的知识,希望对你有一定的参考价值。

首先,JDBC对于SQLSERVER来说默认是支持返回,但对于mysql来说,只默认支持存储过程返回多个ResultSet,那对于手写SQL怎么办。

其实很简单,只要一个在连接字符串中加一个参数:allowMultiQueries=true。

代码实现如下:

@Test
public void test01() throws SQLException, ClassNotFoundException {
    String DBDRIVER = "com.mysql.jdbc.Driver";
    String DBURL = "jdbc:mysql://localhost:3306/bookstore?allowMultiQueries=true";
    String DBUSER = "root";
    String DBPASS = "root";

    Connection conn = null;
    Class.forName(DBDRIVER);
    conn = DriverManager.getConnection(DBURL, DBUSER, DBPASS);
    System.out.println(conn);
    String sql = "SELECT * FROM category;"
            +"SELECT * FROM user;" ;
    Statement stmt = conn.createStatement();

    boolean isResultSet = stmt.execute(sql);
    ResultSet rs = null;
    int count = 0;
    while(true) {
        if(isResultSet) {
            rs = stmt.getResultSet();
            while(rs.next()) {
                System.out.println(rs.getString(1));
            }
            rs.close();
        } else {
            if(stmt.getUpdateCount() == -1) {
                break;
            }
            System.out.printf("Result {} is just a count: {}", count, stmt.getUpdateCount());
        }

        count ++;
        isResultSet = stmt.getMoreResults();
    }
    stmt.close();
    conn.close();
}

以上是关于让java从Mysql返回多个ResultSet的主要内容,如果未能解决你的问题,请参考以下文章

DAO与VO

如何让 mysql 与标签搜索一起获得平均评分?

php - 从mysql返回多个值

MySQL 从多个值中选择,只返回完全匹配

如何从 Java 方法返回多个对象?

如何访问从sql函数获取的java中的多个返回值