Mybatis の 1 次キャッシュについての深い理解

高洛峰
リリース: 2017-01-23 09:33:30
オリジナル
1529 人が閲覧しました

クライアントがデータベース サーバーに毎回同じ 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 サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート