2

この種のクエリを変換することは可能ですか?

SELECT field1, field2 FROM table WHERE SHA1(field1 + field2) = 'hash'; 

NHibernateのCriteria言語に?例:次のようなもの

session.CreateCriteria<Car>()
    .Add(Expression.Eq("SHA1(field1 + field2)", "hash"));
4

1 に答える 1

2

おそらく、この答えはあなたのために働くでしょうか?

https://stackoverflow.com/a/797243

私は次のようなことを試みます:

ISQLFunction sqlAdd = new VarArgsSQLFunction("(", "+", ")");
var concat = Projections.SqlFunction(sqlAdd, NHibernateUtil.String, Projections.Property("ObjectProperty1"), Projections.Property("ObjectProperty2"));
var sha1 = Projections.SqlFunction("SHA1", NHibernateUtil.String, concat);
...
session.CreateCriteria<Car>().Add(Expression.Eq(sha1, "hash"));
于 2012-04-26T22:21:10.240 に答える