我正在尝试使用 EJBQL(带有底层 MySQL 数据源)加入两个 EJB。有问题的两个表是
Machine
- Hostname
- ... unrelated fields ...
和
Location
- Code
- Human readable description
这些表应该在位置代码和机器主机名的前三个字符上左连接。在直接 MySQL 中,命令是:
SELECT * FROM machine m LEFT JOIN location l ON (SUBSTRING(m.`Name`, 1,3) = l.`Code`);
当我将类似的东西放入 EJBQL 时,我得到了各种各样的错误,从空指针异常到无效语法异常——这是我尝试过的:
query="SELECT NEW someObj(m, loc) FROM Machine as m " +
"LEFT JOIN FETCH Location as loc " +
"WHERE (SUBSTRING(m.hostname, 1, :length) = loc.code)"
我也尝试过使用“ON”而不是“WHERE”——但是当我使用 ON 时,EJBQL 会返回一个意想不到的关键字......
那么——以前有没有人成功地做过这样的事情?EJBQL 的文档似乎表明 LEFT 加入是可以的,所以我不确定交易是什么......
谢谢
编辑:我得到的例外是:
outer or full join must be followed by path expression
-- 它与空指针交易被埋在同一行
编辑2:
机器和位置之间没有关系,不幸的是我无法改变它