- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
假设我有一个类 Article
由 Java Ebean 自动映射为数据库表。
对于此表,我想通过 RawSql
检索条目查询,因为当涉及到具有许多连接等的复杂查询时,我发现 SQL 更简单。到目前为止,我已经设法将我的 SQL 语句提供给解析器。查询是正确的,我已经检查过了。
唯一的问题是,我不知道如何将数据库结果映射到我的 Article
类(class)。我知道,有一个 columnMapping(...)
方法,但老实说,我懒得手动映射每一列...
有没有其他方法可以像myResults.mapToClass(Article.class)
一样检索类似 List<Article>
的内容?
这是我已有的代码:
Finder<String, Article> find = new Finder<String, Article>(
String.class, Article.class);
String sql = "SELECT * FROM article [...]";
RawSql rawSql = RawSqlBuilder.parse(sql).create();
List<Article> returnList = find.setRawSql(rawSql).findList();
或者:
Finder<String, Article> find = new Finder<String, Article>(
String.class, Article.class);
String sql = "SELECT id, title, sub_title FROM article [...]";
RawSql rawSql = RawSqlBuilder.parse(sql)
.columnMapping("id", "id")
.columnMapping("title", "title")
.columnMapping("sub_title", "subTitle")
.create();
List<Article> resultList = find.setRawSql(rawSql).findList();
最佳答案
自从提出问题以来,Ebean 发生了很多事情,但我认为问题仍然有效。新的 RawSqlBuilder.tableMapping() 使事情变得更容易,如下面的代码所示,但据我所知,它仍然需要手动映射所有属性(没有 SELECT table.* FROM table
)
我确实遇到了这个问题,并通过创建一个我映射到的辅助对象 (@Entity/@Sql) 解决了这个问题。例如。 CustomerWithPurchaseStats .
摘录:
@Entity
@Sql
public class CustomerWithPurchaseStats {
@OneToOne
private Customer customer;
...
并且在 DAO :
public List<CustomerWithPurchaseStats> getAllCustomersWithPurchaseStats() {
StringBuilder sql = new StringBuilder("SELECT cu.id, <manually add all fields you need mapped ").append(" FROM customer cu ");
RawSqlBuilder rawSqlBuilder = RawSqlBuilder.parse(sql.toString());
rawSqlBuilder.tableAliasMapping("cu", "customer").create();
return Ebean.find(CustomerWithPurchaseStats.class)
.setRawSql(rawSqlBuilder.create())
.findList();
}
关于java - 将 RawSql 结果映射到 Java Ebean 中的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17169921/
我定义了一个没有字段的基本模型,并通过 Ebean 的 eclipse 插件对其进行了增强。然后我用java反编译器反编译,发现ebean给它添加了一些字段和方法: private static St
我有一个 wicket 应用程序,并且正在使用 Ebean ORM 映射。我已在 ebean.properties 中设置了所有凭据。但是当我将其部署到服务器上时,我收到一条错误消息“无法初始化类 c
我想实现的是:当我删除该类别时,它的所有相关文章都可以被删除,当我删除该文章时,它也可以在其相关类别中被删除。 我设置了映射关系@ManyToOne和 @OneToMany(cascade = Cas
我试图复制文档: https://www.playframework.com/documentation/2.5.x/JavaEbean 我按照文档中提到的方式设置了所有内容。 project\plu
我正在尝试进行查询,以检查用户的电子邮件或名称是否以给定的字符串开头。在 sql 查询中,我会使用 name like 'queryString%' or email like 'queryStrin
我有一个带有字段 id 、 name 、 price 等的类产品,... 我只想从表中获取名称.. 我正在使用这个查询 String sql = "select name from produc
我使用的是 Play Framework 2.3,当我尝试创建自己的 SQL 查询时,我总是遇到映射忽略问题。 我不知道是否应该使用 Ebean 来编写这个复杂的 sql 查询。 这是运行良好的 SQ
我有一个模型类,它定义了属于同一类模型的子级列表。保留一个带有一些初始子对象的新对象效果很好,但是当我有两个或更多级别的子对象时,Ebean 似乎无法很好地处理它。这似乎出乎意料,所以我担心我犯了一个
我有一个关于 Ebean 的问题。不幸的是我找不到任何文档来帮助我。我想选择值为 true 且 OneToMany 关系的所有成员也具有 true 值的所有行。 这是一个例子: @Entity pub
我有一个以下模型类。这只是为了测试。 @Entity public class Quest { public static final Find find = new Find() {};
我正在尝试在同一个实体中创建一个@OneToMany 关系。这是一个示例代码: @Entity public class Client extends Model{ private stati
我有一个表,除其他外,它有两列 Long 类型。在我的查询中,我想返回 A 列(长型)等于 B 列(长型)的行。我想在不编写原始 sql 的情况下执行此操作,而是使用更好的方法链接。 到目前为止,我一
我正在尝试在 Java Play 中使用 Ebean 2.3.3 查询部分对象!框架 2.2.1。例如,要获取仅包含 instance_config 中的 id、host 和 publicKey 字段
我在查询要在数据库中搜索自动完成功能的字符串时遇到了一个小问题,我遇到的问题是我需要第一个结果是所有以“开头”的语句,然后是包含该语句的语句字符串! 例如:如果我在数据库的表中得到以下记录: Awes
我有以下代码: @Entity public class Album extends Model { /** * Generated UID */ private
我对 Ebean 的世界是全新的Play Framework 2 中使用的 ORM 持久层。我最初的印象非常好,但在我的业余项目中,我偶然发现了我不知道如何解决的问题。我不确定我是否做错了什么(模型?
我正在尝试进行查询,以检查帐户信息是否处于 Activity 状态(boolean = True)及其针对该用户的信息(来自模型的用户 ID)。在 SQL 中我会这样写 Select * from m
我喝了一些 Gin ,我喝了一些补品,它们是多对多关系。现在我还有一张 table gin2tonic。它只有 2 个键,它们都与 tonic 和 gin 的 id 无关。 我想用匹配的补品检索所有
Ebean ORM 是 Play 的首选 ORM! Java 框架。当我在构建自己的对象关系映射器和其他对象关系行为模式以及使用 ORM 之间做出选择时,我觉得非常重要的一个标准是 Ebeans 是否
我创建了使用 Ebeans 的示例应用程序: 型号: @Entity public class Numm extends Model { @Id private long id;
我是一名优秀的程序员,十分优秀!