3

我在 Oracle 中有一个场景,我需要将列的子字符串部分与值列表匹配。我正在使用 sqlfunction 投影在所需列上应用子字符串,并将该投影添加为 In 子句限制的一部分。以下是我为此编写的简化标准。

ICriteria criteriaQuery = session.CreateCriteria<Meeting>()
    .Add(Restrictions.In(
        Projections.SqlFunction(
            "substring",
            NHibernateUtil.String,
            Projections.Property("Code"),
            Projections.Constant(1),
            Projections.Constant(3)),
        new string[] { "D01", "D02" }))
        .Add(Restrictions.In("TypeId", meetingTypes));

我遇到的问题是生成的 SQL 是错误的,其中为语句注册的参数数量超过了语句实际使用的数量,并且即使未使用某些参数也会重复。这会导致语句失败并显示消息 - ORA-01036:非法变量名称/编号。生成的查询

SELECT this_.Meeting_id as Meeting1_0_2_, .....  
WHERE substr(this_.Mcs_Main, :p0, :p1) in (:p2, :p3) 
and this_.Meeting_Type_Id in (:p4, :p5);
:p0 = 1, :p1 = 3, :p2 = 1, :p3 = 3, :p4 = 'D02', :p5 = 'D03', :p6 = 101, :p7 = 102

p2 和 p3 再次生成并且是 p0, p1 的副本,因此整个查询都失败了。

我可以通过用公式映射新属性来临时解决这个问题,但我认为这不是正确的方法,因为即使我不需要评估子字符串,公式也会始终执行。

关于与 In 子句组合使用时投影是否正常工作的任何建议,当我使用 Equal Restriction 而不是 In 时,相同的投影工作正常。

4

1 回答 1

0

此错误已在 3.0.0.GA 版本中修复。

于 2011-02-03T19:27:33.257 回答