SQLException:列索引超出了Play Framework中的Ebean和rawSql

时间:2018-05-17 09:25:07

标签: java playframework ebean

所以在寻找一天后,我仍然不知道我在这里做错了什么。我想在我的表实验室中选择包含6列的服务器中的列名,但我不断收到错误:“SQLException:列索引超出范围:0,列数:1”。有人熟悉这个吗?谢谢 这是我的代码:

    String sql = "SELECT name FROM Laboratory";
    RawSql rawSql = RawSqlBuilder
            .parse(sql)
            .create();
    Query<Laboratory> query = Ebean.find(Laboratory.class);
    query.setRawSql(rawSql).where();
    List<Laboratory> results = query.findList();

    results.sort(Comparator.comparing(Laboratory::getName)); // Sort by alphabetical order
    try {
        String json = JsonHelper.toJSON(results);
        return ok(json).as("application/json");
    } catch (JsonProcessingException e) {
        LOG.error("Unable to serialize sql request", e);
        return internalServerError();
    }

1 个答案:

答案 0 :(得分:0)

好的,我找到了解决方案。事实证明,除了名称之外,我只需要获取id,否则Ebean就会丢失。最后这里是有效的sql请求:

String sql = "SELECT id, name FROM Laboratory";