在Play应用程序(2.2.x)中,我使用RawSql来获取对象,并且出现以下异常:
Execution exception[[PersistenceException: No ScalarType registered for class java.util.ArrayList]]
我的模型基本上看起来像
@Entity()
public class Metadata extends Model {
public static Model.Finder<String, Metadata> find = new Model.Finder<String, Metadata>(String.class, Metadata.class);
@Id
public String recordID;
@ManyToMany(cascade = CascadeType.REMOVE)
public List<Keyword> keywords = new ArrayList<Keyword>();
}
和
@Entity
public class Keyword extends Model {
@Id
public String keyword;
public static Model.Finder<String, Keyword> find = new Model.Finder<String, Keyword>(String.class, Keyword.class);
}
和一个小助手豆
@Entity()
@Sql()
public class RecordId extends Model {
@Id
public String recordId;
}
现在,我想查找所有具有关键字列表的记录。所以我写了一个RawSql看起来像这样
SELECT metadata_record_id as recordId
FROM metadata_keyword
WHERE keyword_keyword IN (?)
GROUP BY recordId
HAVING count(recordId) = ?
ORDER BY recordId
在我的控制器中,我使用setParameter填充参数。
RawSql rawSql = RawSqlBuilder.parse(sql).create();
List<RecordId> query = Ebean.find(RecordId.class).setRawSql(rawSql)
.setParameter(1, stringList)
.setParameter(2, stringList.size())
.findList();
我在这里想念什么?将字符串列表转换为逗号分隔的字符串不起作用,这是我所期望的。我可以只连接查询字符串,而不使用setParameter(),但是我猜想(至少在理论上)SQL注入容易。
最佳答案
我知道这已经很老了,您会继续前进的,但是,
这是这条线
在哪里keyword_keyword IN(?)
卸下侧面的()。
那应该做。
而且,最好给它们命名而不是那样使用。