首页 > 解决方案 > jooq sql builder输出给出“?” 在 WHERE 子句中的 eq()

问题描述

我在这里复制示例代码:

整个代码块看起来像这样

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import org.jooq.DSLContext;
import org.jooq.SQLDialect;
import static org.jooq.impl.DSL.*;


public static String sampleSql() {
    DSLContext create = DSL.using(SQLDialect.MYSQL);
    String sql = create.select(field("BOOK.TITLE"), field("AUTHOR.FIRST_NAME"), field("AUTHOR.LAST_NAME"))
            .from(table("BOOK"))
            .join(table("AUTHOR"))
            .on(field("BOOK.AUTHOR_ID").eq(field("AUTHOR.ID")))
            .where(field("BOOK.PUBLISHED_IN").eq(1948))
            .getSQL();
    return sql;
}

的输出sampleSql()

select BOOK.TITLE, AUTHOR.FIRST_NAME, AUTHOR.LAST_NAME from BOOK join AUTHOR on BOOK.AUTHOR_ID = AUTHOR.ID where BOOK.PUBLISHED_IN = ?

但是为什么问号“?”,问号应该是1948。我错过了什么?

标签: sqljooq

解决方案


getSQL()用 ? 返回准备好的语句 作为参数占位符。

如果要内联必须调用的参数:

getSQL(ParamType.INLINED);

请在此处找到 API 文档:https ://www.jooq.org/javadoc/latest/org.jooq/org/jooq/Query.html


推荐阅读