クライアントがデータベース サーバーに毎回同じ SQL クエリ ステートメントを送信すると、パフォーマンスが低下します。
では、どうすれば改善できるのでしょうか?
mybatis は、第 1 レベルのキャッシュ戦略を提供します
sqlSession の開始と終了の間、キャッシュされたオブジェクトは sqlSession オブジェクト (実際には Executor) 内に保持されます。キャッシュ データが存在する場合は直接取得され、存在しない場合は SQL クエリがデータベースに送信され、クエリ データがキャッシュに格納されてプログラムに返されます。
問題が発生します:
最初と 2 回目のクエリ中に、プログラムがクエリ対象のデータベースのデータを変更すると、読み取られたデータが間違ったものになります。つまり、
ダーティ読み取りになります。 mybatis は、sqlSession が commit() メソッドを実行した後、このキャッシュをクリアします。 2 回目のクエリでも、データベースからクエリを実行します
sqlSession の clearCache() メソッドを手動で呼び出してキャッシュをクリアすることもできます
小さな例:
@Test public void testCacheLever1() throws Exception{ SqlSession session = factory.openSession(); UserMapper mapper = session.getMapper(UserMapper.class); //第一次请求,查询id为1的用户 User user = mapper.findUserById(1); System.out.println(user); //更改数据,会清空缓存 user.setUsername("yyyy"); mapper.updateUser(user); session.commit(); //第二次查询会从缓存中找 User user2 = mapper.findUserById(1); System.out.println(user2); session.close(); }
問題:
If sqlSessionが閉じられると、キャッシュもクリアされます。キャッシュを使用して効率を向上させるにはどうすればよいですか?
さて、次の記事では mybatis の 2 次キャッシュについて紹介します。
上記は編集者によって紹介された Mybatis の 1 次キャッシュです。ご質問がございましたら、メッセージを残してください。編集者がすぐに返信します。また、PHP 中国語 Web サイトをサポートしていただきありがとうございます。
Mybatis 1 次キャッシュ関連の記事をさらに詳しく理解するには、PHP 中国語 Web サイトに注目してください。