首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >JDBC ()某一行如何获得结果

JDBC ()某一行如何获得结果
EN

Stack Overflow用户
提问于 2019-11-29 01:11:30
回答 1查看 97关注 0票数 0

我对JDBC非常陌生,我正在练习执行查询和语句。

代码语言:javascript
复制
try {
            Connection conn = DriverManager.getConnection(DB_URL, USERNAME, PASSWORD);

            Statement st = conn.createStatement();

            String query = "SELECT COUNT(*) AS \"Number of suppliers\", city\r\n" + 
                    "FROM supplier\r\n" + 
                    "GROUP BY city\r\n" + 
                    "ORDER BY city DESC\r\n";
            //st.executeUpdate(query);

            ResultSet rs = st.executeQuery(query);  

            while(rs.next()) {
                System.out.println(rs.getString("supplierNum"));
                System.out.println(rs.getString("city"));
                space();
            }   

        st.close();
        conn.close();

        }

我正在尝试使用SELECT COUNT(supplierNum) AS "Number of suplliers", cityFROM supplierGROUP BY city ORDER BY city DESC;执行和打印结果。

控制台只是终止,没有发生,没有错误消息,没有,只有一个空白的屏幕。

这是我要访问的桌子

代码语言:javascript
复制
CREATE TABLE supplier 
(
    supplierNum CHAR(2) NOT NULL,
    name CHAR(10) NOT NULL,
    status TINYINT(4) NOT NULL,
    city VARCHAR(10) NOT NULL,

    PRIMARY KEY (supplierNum)
);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-29 01:17:50

您将count列别名为"Number of suplliers",但是您的JDBC代码正在尝试查找supplierNum。在任何地方都使用一致的别名来解决这个问题:

代码语言:javascript
复制
String query = "SELECT city, COUNT(*) AS supplierCnt " + 
               "FROM supplier " + 
               "GROUP BY city " + 
               "ORDER BY city DESC";

ResultSet rs = st.executeQuery(query); 

while (rs.next()) {
    System.out.println(rs.getString("supplierCnt"));
    System.out.println(rs.getString("city"));
    space();
}   
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59097689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档