1

NHibernate を Sybase ASA9 で動作させようとすると、名前付きパラメーターに問題が発生してエラーが発生します。

Invalid index 0 for this AsaParameterCollection with Count=0.

NHibernate ODBC ドライバーと現在は ASA ドライバーを試しました。パラメータなしで直接クエリを実行できるので、接続が行われていることがわかります。パラメータが ASA に正しく渡されていないようですが、何か間違ったことをしているのか、それとも単に NH と ASA の問題なのかを突き止めようとしています。これまでに少し頭を悩ませたので、これは将来誰かを助けるかもしれません. 値は正しく、生成された sql の最後のスニペットに表示されます。クエリは有効な Sybase のように見える等号疑問符で終わりますが、これがどこで壊れているのかはっきりしません。

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
  <session-factory>
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="dialect">NHibernate.Dialect.SybaseASA9Dialect</property>
    <property name="connection.driver_class">NHibernate.Driver.SybaseAsaClientDriver</property>
    <property name="connection.connection_string">Uid=;Pwd=;Dsn=</property>
    <property name="hbm2ddl.keywords">none</property><!--could cause problems? update needed when going to sybase driver instead of odbc-->
    <property name="show_sql">true</property>
    <!-- mapping files -->
    <mapping resource="domain.table.hbm.xml" assembly="Label3700" />-->
  </session-factory>
</hibernate-configuration>

マッピング

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
               assembly="Label3700"
               namespace="Label3700.Domain">

<class name="menu_item" table="micros.mi_def">
     <id name="mi_seq">
       <column name="mi_seq" sql-type="integer" not-null="true"/>
       <generator class="identity" />
     </id>
     <property name="obj_num" />
     <property name="name_1" />
     <property name="fam_grp_seq" />
   </class>
</hibernate-mapping>

クラス

public class menu_item
{
    public virtual int mi_seq { get; set; }
    public virtual int obj_num { get; set; }
    public virtual string name_1 { get; set; }
    public virtual int fam_grp_seq { get; set; }
}

クエリ

IList<menu_item> mi = session.CreateQuery("FROM menu_item m where m.fam_grp_seq = :famGrpSeq")
.SetParameter("famGrpSeq", familyGroupSeq)
.List<menu_item>();

エラー

could not execute query
[ select menu_item0_.mi_seq as mi1_1_, menu_item0_.obj_num as obj2_1_,menu_item0_.name_1 as name3_1_, menu_item0_.fam_grp_seq as fam4_1_ from micros.mi_def menu_item0_ where menu_item0_.fam_grp_seq=? ]
Name:famGrpSeq - Value:44
[SQL: select menu_item0_.mi_seq as mi1_1_, menu_item0_.obj_num as obj2_1_,menu_item0_.name_1 as name3_1_, menu_item0_.fam_grp_seq as fam4_1_ from micros.mi_def menu_item0_ where menu_item0_.fam_grp_seq=?]
4

1 に答える 1

0

デフォルトの接続ドライバーは間違った設定を使用するため、カスタム接続ドライバーを作成する必要があります。NHibernate の新しいバージョンにアップグレードすると、問題が解消される場合があります。

sybase の接続ドライバで、次のプロパティをオーバーライドしました。

public class SqlAnywhereConnectionDriver : ReflectionBasedDriver
{
    //other code removed…
    public override bool UseNamedPrefixInSql
    {
        get { return true; }
    }

    public override bool UseNamedPrefixInParameter
    {
        get { return true; }
    }

    public override string NamedPrefix
    {
        get { return ":"; }
    }
}
于 2015-12-08T20:36:28.253 に答える