为啥我可以使用 SELECT 而不是 CALL 调用 HSQL 函数?

Posted

技术标签:

【中文标题】为啥我可以使用 SELECT 而不是 CALL 调用 HSQL 函数?【英文标题】:Why can I invoke an HSQL function with SELECT but not CALL?为什么我可以使用 SELECT 而不是 CALL 调用 HSQL 函数? 【发布时间】:2012-09-05 15:50:55 【问题描述】:

根据HSQL documentation,只有SQL 过程需要CALL 语法。我正在编写一个 SQL 函数,但我不能从中 SELECT。我只能CALL它。谁能看到我错过的东西?这是我的代码

public static void main(String[] args) throws Exception 
    Class<?> driverClass = Class.forName("org.hsqldb.jdbcDriver");
    JDBCDriver driver = (JDBCDriver) driverClass.newInstance();
    Properties props = new Properties();
    props.setProperty("user", "sa");
    props.setProperty("password", "");
    Connection c = driver.connect("jdbc:hsqldb:mem:aname", props);
    execute(c, "CREATE TABLE T (i INT)");
    execute(c, "INSERT INTO T VALUES (1)");
    execute(c, "CREATE FUNCTION f() RETURNS TABLE (i INT) READS SQL DATA " +
            " RETURN TABLE (SELECT * FROM T)");
    System.out.println("Call returns the ResultSet:");
    execute(c, " CALL f() ");
    try 
        execute(c, "SELECT * FROM f()");
     catch (Exception e) 
        System.out.println("Select throws the exception:");
        System.out.println(e);
    


private static void execute(Connection c, String sql) throws SQLException 
    Statement s = c.createStatement();
    try 
        s.execute(sql);
        ResultSet rs = s.getResultSet();
        if (rs != null) 
            printResultSet(rs);
        
     finally 
        s.close();
    


private static void printResultSet(ResultSet rs) throws SQLException 
    try 
        while (rs.next()) 
            int columnCount = rs.getMetaData().getColumnCount();
            for (int i = 1; i <= columnCount; i++) 
                System.out.println(rs.getObject(i));
            
        
     finally 
        rs.close();
    

我得到了输出:

Call returns the ResultSet:
1
Select throws the exception:
java.sql.SQLSyntaxErrorException: user lacks privilege or object not found: F

【问题讨论】:

【参考方案1】:

选择该函数返回的表的正确语法如下:

SELECT * FROM TABLE(F())

【讨论】:

【参考方案2】:

好像还没有实现。

目前 HSQLDB FUNCTION 不能有 out 参数。它可以返回一个 单值结果或表,由 execute() 调用返回。

http://sourceforge.net/tracker/index.php?func=detail&aid=3530755&group_id=23316&atid=378134

【讨论】:

以上是关于为啥我可以使用 SELECT 而不是 CALL 调用 HSQL 函数?的主要内容,如果未能解决你的问题,请参考以下文章

x86上为啥C语言调用一个函数要先把参数压栈,之后才是返回地址

为啥函数可以修改调用者感知的某些参数,而不能修改其他参数?

Python:使用 subprocess.call 获取输出,而不是 Popen [重复]

Angular - 为啥我得到对象而不是对象数组?

MySQL 查询调优 - 为啥使用变量中的值比使用文字慢得多?

为啥元类的 __call__ 方法在类上调用,而原生类的 __call__ 没有?