首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JavaDB匿名列名称

JavaDB匿名列名称
EN

Stack Overflow用户
提问于 2013-07-16 21:38:38
回答 1查看 132关注 0票数 2

我正在尝试创建一个像这样的通用UPDATE-statement,其中只有表名是固定的。

代码语言:javascript
复制
updateValueQuery = conn.prepareStatement("UPDATE TABLENAME SET (?)=(?)");

这将失败,并显示SQLException对语法的抱怨。只要我像这样指定column-name:

代码语言:javascript
复制
updateValueQuery = conn.prepareStatement("UPDATE TABLENAME SET COL_NAME=(?)");

SQL愉快地编译。有没有办法让列名也匿名呢?

我使用的是Apache derby。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-07-16 21:59:31

不,PreparedStatement只有值的定位符。我通过以下方式解决了类似的问题:

代码语言:javascript
复制
    private final String FIND_STRING = "select * from TABLENANE where {0} = ?";
       .
       .
       .
    private final Map<String, PreparedStatement> statements = new HashMap<String, PreparedStatement>();

    private PreparedStatement prepareStatement(String field, String toFind) throws SQLException{
       PreparedStatement statement = null;
       if (statements.contains(field)){
          statement = statements.get(field);
       }else{
          String findInHelpDefinition = MessageFormat.format(FIND_STRING, field));
          statement = connection.prepareStatement(findInHelpDefinition);
          statemnts.put(field, statement);
       }
       statement.setString(1, toFind);
       return statement;
    }
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17678097

复制
相关文章

相似问题

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