gpt4 book ai didi

java - 在列上使用别名的查询会出错

转载 作者:搜寻专家 更新时间:2023-10-31 19:49:16 24 4
gpt4 key购买 nike

当我为列使用别名时出现错误。没有别名,everytinig 工作得很好。那有什么问题?这是一个简单的例子,但在实际项目中需要使用更多的别名来将结果包装在一些非实体类中,但由于这个错误而不能。如何解决这个问题?

不工作(在 id 列上有别名):

public List<Long> findAll(Long ownerId) {
String sql = "select id as myId from products where ownerId = "+ownerId;
SQLQuery query = getSession().createSQLQuery(sql);
return query.list();
}

错误:

WARN [JDBCExceptionReporter:77] : SQL Error: 0, SQLState: S0022 ERROR [JDBCExceptionReporter:78] : Column 'id' not found.

正在工作(没有别名):

public List<Long> findAll(Long ownerId) {
String sql = "select id from products where ownerId = "+ownerId;
SQLQuery query = getSession().createSQLQuery(sql);
return query.list();
}

最佳答案

如果您的“产品”已映射, hibernate 可能不知道“myId”,因此无法选择它。你可以尝试这样的事情:

getSession().createSQLQuery(sql).addScalar("myId", Hibernate.LONG)

关于java - 在列上使用别名的查询会出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7118703/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com