- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用的是 Play Framework 2.3,当我尝试创建自己的 SQL 查询时,我总是遇到映射忽略问题。
我不知道是否应该使用 Ebean 来编写这个复杂的 sql 查询。
这是运行良好的 SQL 查询:
SELECT g.id,
concat(g.client_id,'-',trim(to_char(n.number,'099999'))) as reference,
(
SELECT sum(total_ttc)
from global_commission_invoice_line
where global_commission_invoice_id= g.id
) as totalTTC
from global_commission_invoice g
LEFT JOIN invoice_number n on g.invoice_number_id = n.id
LEFT JOIN client c2 on g.client_id = c2.id
我尝试用 ebean 解析它,因为我有一个带参数的 WHEN 子句。
我的 java 代码大致如下。
String sql = " SELECT g.id, " +
" concat(g.client_id,'-',trim(to_char(n.number,'099999'))) as reference," +
" (" +
" SELECT sum(total_ttc)" +
" from global_commission_invoice_line" +
" where global_commission_invoice_id= g.id" +
" ) as totalTTC " +
" from global_commission_invoice g" +
" LEFT JOIN invoice_number n on g.invoice_number_id = n.id" +
" LEFT JOIN client c2 on g.client_id = c2.id";
// Create sql
RawSql rawSql = RawSqlBuilder.parse(sql)
.columnMapping("g.id","id")
.columnMappingIgnore("concat(g.client_id,'-',trim(to_char(n.number,'099999')))")
.columnMappingIgnore("( SELECT sum(total_ttc) from global_commission_invoice_line where global_commission_invoice_id= g.id )")
.create();
return Ebean.find(models.GlobalCommissionInvoice.class).setRawSql(rawSql)
.findList()
此映射忽略成功并且没有错误:
.columnMappingIgnore("( SELECT sum(total_ttc) from global_commission_invoice_line where global_commission_invoice_id= g.id )")
但是这个:
.columnMappingIgnore("concat(g.client_id,'-',trim(to_char(n.number,'099999')))")
返回此错误:
Execution exception[[IllegalArgumentException: DB Column [ concat(g.client_id, '-', trim(to_char(n.number, '099999')))] not found in mapping. Expecting one of [[g.id, concat(g.client_id, '-', trim(to_char(n.number, '099999'))), ( SELECT sum(total_ttc) from global_commission_invoice_line where global_commission_invoice_id= g.id )]]]]
有时我发现错误,大约是一个空格或一个换行符放错位置,但我从来不知道如何在复杂的查询中使用它,而不需要花几个小时搜索为什么会出现错误。
我应该使用 ebean 来执行这种类型的 sql 查询吗?我是否严重使用了映射忽略?
附注:抱歉我的英语不好,我是法国人
最佳答案
我已经找到解决办法了。我调试 ebean RawSql 类 并使我的映射与 ebean 映射匹配。
Ebean 在每个逗号处切片 SELECT 语句,因此我的 concat 函数被分成 3 部分。
解决方案:
// Create sql
RawSql rawSql = RawSqlBuilder.parse(sqlStringBuilder.getStrStatement())
.columnMapping("g.id","id")
.columnMappingIgnore("concat(g.client_id")
.columnMappingIgnore("'-'")
.columnMappingIgnore("trim(to_char(n.number")
.columnMappingIgnore("'099999')))")
.columnMappingIgnore("( SELECT sum(total_ttc) from global_commission_invoice_line where global_commission_invoice_id= g.id )")
.create();
关于java - 玩映射忽略RawSQL Ebean,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52273376/
我定义了一个没有字段的基本模型,并通过 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;
我是一名优秀的程序员,十分优秀!