- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
以下Ebean查找
String join = "trackToArtists.artist.artistToTags.tag.stationToTags.station";
return find
.where()
.eq(join, station)
.ge(join + ".energyMin", settings.energyMin)
.le(join + ".energyMax", settings.energyMax)
.ge(join + ".livenessMin", settings.livenessMin)
.le(join + ".livenessMax", settings.livenessMax)
.ge(join + ".tempoMin", settings.tempoMin)
.le(join + ".tempoMax", settings.tempoMax)
.ge(join + ".acousticnessMin", settings.acousticnessMin)
.le(join + ".acousticnessMax", settings.acousticnessMax)
.ge(join + ".danceMin", settings.danceMin)
.le(join + ".danceMax", settings.danceMax)
.orderBy("trackToArtists.artist.artistToTags.score DESC")
.setMaxRows(Util.TopN)
.findList();
似乎生成了不正确的 SQL 查询,特别是 ORDER_BY:
Syntax error in SQL statement "SELECT DISTINCT T0.ID ... AND U6.DANCE_MAX <= ? ORDER BY $ RACKTOARTISTS[*].ARTIST.ARTISTTOTAGS SCORE DESC
完整 SQL(由 Ebean 生成):
SELECT DISTINCT T0.ID C0, T0.ACTIVE C1, T0.NAME C2, T0.MD5 C3, T0.EN_TRACK_ID C4, T0.EN_SONG_ID C5, T0.LASTR C6, T0.LAST_LISTENER_COUNT C7, T0.LAST_PLAY_COUNT C8, T0.LAST_PLAY_COUNT_NORM C9, T0.MB_ID C10, T0.EN_ANALYZER_VERSION C11, T0.DURATION C12, T0.EN_DANCEABILITY C13, T0.ENNERGY C14, T0.EN_KEY C15, T0.EN_KEY_CONFIDENCE C16, T0.LOUDNESS C17, T0.LOUDNESS_NORM C18, T0.EN_MODE C19, T0.EN_MODE_CONFIDENCE C20, T0.EN_TEMPO C21, T0.EN_TEMPO_CONFIDENCE C22, T0.EN_TEMPO_NORM C23, T0.EN_TIME_SIGNATURE C24, T0.EN_TIME_SIGNATURE_CONFIDENCE C25, T0.EN_SONG_HOTNESS C26, T0.EN_SPEECHINESS C27, T0.EN_ACOUSTICNESS C28, T0.EN_LIVENESS C29, T0.ENVALENCE C30, T0.LAST_ID C31, T0.LAST_URL C32 FROM TRACK T0 JOIN TRACK_TO_ARTIST U1 ON U1.TRACK_ID = T0.ID JOIN ARTIST U2 ON U2.ID = U1.ARTIST_ID JOIN ARTIST_TO_TAG U3 ON U3.ARTIST_ID = U2.ID JOIN TAG U4 ON U4.ID = U3.TAG_ID JOIN STATION_TO_TAG U5 ON U5.TAG_ID = U4.ID JOIN STATION U6 ON U6.ID = U5.STATION_ID WHERE U5.STATION_ID = ? AND U6.ENERGY_MIN >= ? AND U6.ENERGY_MAX <= ? AND U6.LIVENESS_MIN >= ? AND U6.LIVENESS_MAX <= ? AND U6.TEMPO_MIN >= ? AND U6.TEMPO_MAX <= ? AND U6.ACOUSTICNESS_MIN >= ? AND U6.ACOUSTICNESS_MAX <= ? AND U6.DANCE_MIN >= ? AND U6.DANCE_MAX <= ? ORDER BY $ RACKTOARTISTS[*].ARTIST.ARTISTTOTAGS SCORE DESC LIMIT 11
我什至不知道是什么导致它将“trackToArtists”解释为“$ RACKTOARTISTS”。
最佳答案
尝试这样做:
find.fetch("trackToArtists.artist.artistToTags")
.where()
.eq(join, station)
.ge(join + ".energyMin", settings.energyMin)
.le(join + ".energyMax", settings.energyMax)
.ge(join + ".livenessMin", settings.livenessMin)
.le(join + ".livenessMax", settings.livenessMax)
.ge(join + ".tempoMin", settings.tempoMin)
.le(join + ".tempoMax", settings.tempoMax)
.ge(join + ".acousticnessMin", settings.acousticnessMin)
.le(join + ".acousticnessMax", settings.acousticnessMax)
.ge(join + ".danceMin", settings.danceMin)
.le(join + ".danceMax", settings.danceMax)
.orderBy("trackToArtists.artist.artistToTags.score DESC")
.setMaxRows(Util.TopN)
.findList();
关于java - 玩Ebean .orderBy()坏了?将字符替换为 "$ ",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30785593/
我定义了一个没有字段的基本模型,并通过 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;
我是一名优秀的程序员,十分优秀!