Das funktioniert nicht, weil Sie versuchen, :value
mit "person.LAST_NAME = 'Johnson'"
ersetzen wollen, dass die Abfrage
Das wird nicht funktionieren
SELECT person.ID, person.SSN, person.LAST_NAME, person.MIDDLE_NAME, person.FIRST_NAME
FROM PERSONS as person
where person.LAST_NAME = 'Johnson'
wird. Sie können den "Johnson" -Teil nicht dynamisch ersetzen, nicht die ganze Bedingung. So wirklich bekommt, was erzeugt wird,
SELECT person.ID, person.SSN, person.LAST_NAME, person.MIDDLE_NAME, person.FIRST_NAME
FROM PERSONS as person
where 'person.LAST_NAME = \'Johnson\''
die offensichtlich keine gültige Bedingung für die WHERE-Teil ist, da es nur eine wörtliche, aber keine Spalte und Betreiber das Feld zu vergleichen.
Wenn Sie nur gegen person.LAST_NAME
anzupassen haben zu umschreiben die XML-SQL-Abfrage
<sql-query name="PersonQuery" resultset-ref="PersonSet" read-only="true" >
<![CDATA[
SELECT
...
FROM PERSONS as person
where person.LAST_NAME = :value
]]>
</sql-query>
Und in der C# -Code gesetzt
String query = "Johnson";
Wenn Sie dynamisch von verschiedenen Spalten filtern müssen oder Auch mehrere Spalten gleichzeitig verwenden Filter. z.B.so (habe ich ein paar Annahmen über Sie Hibernate-Mapping-Datei)
<hibernate-mapping>
...
<class name="Person">
<id name="id" type="int">
<generator class="increment"/>
</id>
...
<filter name="ssnFilter" condition="ssn = :ssnValue"/>
<filter name="lastNameFilter" condition="lastName = :lastNameValue"/>
<filter name="firstNameFilter" condition="firstName = :firstNameValue"/>
<filter name="middleNameFilter" condition="middleName = :middleNameValue"/>
</class>
...
<sql-query name="PersonQuery" resultset-ref="PersonSet" read-only="true" >
...
FROM PERSONS as person
]]>
</sql-query>
<!-- note the missing WHERE clause in the PersonQuery -->
...
<filter-def name="ssnFilter">
<filter-param name="ssnValue" type="int"/>
</filter-def>
<filter-def name="lastNameFilter">
<filter-param name="lastNameValue" type="string"/>
</filter-def>
<filter-def name="middleNameFilter">
<filter-param name="midlleNameValue" type="string"/>
</filter-def>
<filter-def name="firstNameFilter">
<filter-param name="firstNameValue" type="string"/>
</filter-def>
</hibernate-mapping>
in Ihrem Code Jetzt sollten Sie in der Lage sein
String lastName = "Johnson";
String firstName = "Joe";
//give me all persons first
HibernateTemplate.FindByNamedQuery("PersonQuery");
//just give me persons WHERE FIRST_NAME = "Joe" AND LAST_NAME = "Johnson"
Filter filter = HibernateTemplate.enableFilter("firstNameFilter");
filter.setParameter("firstNameValue", firstName);
filter = HibernateTemplate.enableFilter("lastNameFilter");
filter.setParameter("lastNameValue", lastName);
HibernateTemplate.FindByNamedQuery("PersonQuery");
//oh wait. Now I just want all Johnsons
HibernateTemplate.disableFilter("firstNameFilter");
HibernateTemplate.FindByNamedQuery("PersonQuery");
//now again give me all persons
HibernateTemplate.disableFilter("lastNameFilter");
HibernateTemplate.FindByNamedQuery("PersonQuery");
zu tun Wenn Sie noch mehr dynamische Abfragen (zB auch brauchen Veränderung der Operator (=,! =, like,>, <, ...) oder du musst die Einschränkungen logisch kombinieren (wo lastname = "foo" OR Vorname "=" foobar ") dann ist es definitiv Zeit in die zu schauen
Hibernate Criteria API