MyBatis キャッシュ メカニズムの分析: 1 次キャッシュと 2 次キャッシュの違いと応用
MyBatis フレームワークでは、キャッシュは非常に重要な機能です。データベース操作のパフォーマンスを向上させる効果があります。そのうち、一次キャッシュと二次キャッシュは、MyBatis でよく使用される 2 つのキャッシュ メカニズムです。この記事では、一次キャッシュと二次キャッシュの違いと用途を詳細に分析し、具体的なコード例を示して説明します。
1. 一次キャッシュ
一次キャッシュはローカル キャッシュとも呼ばれ、デフォルトで有効になっており、オフにすることはできません。第 1 レベルのキャッシュは SqlSession レベルのキャッシュです。つまり、同じ SqlSession で実行されるクエリ操作は同じキャッシュを共有します。クエリ文の実行後、クエリ結果は SqlSession のキャッシュに保存され、再度同じクエリ文を実行すると、MyBatis は再度データベースにアクセスすることなく、キャッシュから直接結果を取得します。
一次キャッシュの特徴は次のとおりです。
次は、一次キャッシュを使用するサンプル コードです:
SqlSession sqlSession = sqlSessionFactory.openSession(); try { UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user1 = userMapper.getUserById(1); User user2 = userMapper.getUserById(1); System.out.println(user1 == user2); // 输出true,表示对象是相同的 } finally { sqlSession.close(); }
上の例では、まず ID 1 のユーザー オブジェクトを取得し、それを最初のキャッシュに格納します。 -level キャッシュを使用して、同じクエリ ステートメントを再度実行します。出力が true であることがわかります。これは、2 回取得されたオブジェクトが同じであることを意味します。これが 1 次キャッシュの役割です。
2. 第 2 レベル キャッシュ
第 2 レベル キャッシュはマッパー レベルのキャッシュであり、SqlSession 全体で共有され、複数の SqlSession 間のデータ共有効率を向上させることができます。ただし、二次キャッシュは手動で構成して有効にする必要があり、一次キャッシュのようにデフォルトでは有効になっていないことに注意してください。
2次キャッシュの特徴は次のとおりです:
次は、2 次キャッシュを使用するためのサンプル コードです。
まず、MyBatis 構成ファイルで次のように設定します。
次に、対応するマッパー次のアノテーションをインターフェイスに追加します:
@CacheNamespace public interface UserMapper { User getUserById(int id); }
次に、キャッシュする必要があるクエリ メソッドに @Select アノテーションを追加し、useCache=true を設定します:
@Select("select * from user where id = #{id}") @Options(useCache=true) User getUserById(int id);
上記の設定により、getUserById メソッドには 2 つのレベル キャッシュの機能があり、SqlSession 間でデータを共有できます。
要約すると、この記事では、MyBatis における 1 次キャッシュと 2 次キャッシュの違いと用途を詳細に分析し、説明のための具体的なコード例を示します。キャッシュメカニズムを適切に使用すると、データベース操作のパフォーマンスが効果的に向上し、システムの応答速度が向上します。これは、開発時に重点を置く必要がある部分です。この記事が、読者が MyBatis のキャッシュ メカニズムをよりよく理解し、適用するのに役立つことを願っています。
以上がMyBatisのキャッシュ機構を解析:一次キャッシュと二次キャッシュの特徴と使い方を比較の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。