2

以下のコード スニペットでは、休止状態のクエリを使用しています。それは正常に動作します。このコードを実行すると、クエリキャッシュから選択されるため、2回目のクエリは起動されません

   Session session = hibernateFactory.openSession();
    Query employeeQuery=session.createQuery("from Employee where employeeId=1");//line 1
    employeeQuery.setCacheable(true);
    Employee employee1=(Employee)employeeQuery.uniqueResult();
    session.close();

しかし、上記のコードスニペットの line1 を以下の行に置き換えるとすぐに、例外が発生します

Query employeeQuery=session.createSQLQuery("select * from Employee where employeeId=1");

例外は

    Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
at org.hibernate.type.TypeHelper.disassemble(TypeHelper.java:146)
at org.hibernate.cache.StandardQueryCache.put(StandardQueryCache.java:106)
at org.hibernate.loader.Loader.putResultInQueryCache(Loader.java:2434)
at org.hibernate.loader.Loader.listUsingQueryCache(Loader.java:2321)
at org.hibernate.loader.Loader.list(Loader.java:2268)

クエリ キャッシュはネイティブ クエリには適用できませんか?

更新:-クエリキャッシュは、ネイティブ SQL ではなく HQL に適用できると思います。しかし、休止状態のドキュメントでは、どこにも書かれていません。だから、私はここに何か欠けているのだろうかと思っています

4

1 に答える 1

2

SQLQuery はキャッシュをサポートしていません。それはあなたを助けることができます。

http://www.tutorialspoint.com/hibernate/hibernate_caching.htm

休止状態の SQL 構文を使用することをお勧めします。

于 2013-03-24T06:07:03.497 に答える