Heim  >  Artikel  >  Java  >  So verwenden Sie den Second-Level-Cache von Mybatis in Java

So verwenden Sie den Second-Level-Cache von Mybatis in Java

PHPz
PHPznach vorne
2023-05-24 18:16:061836Durchsuche

    Übersicht und Klassifizierung des Caches

    Übersicht

    Der Cache ist ein Stück Speicherplatz . Temporäre Daten speichern

    Warum Cache verwenden

    Lesen Sie die Daten aus der Datenquelle (Datenbank oder Datei) und speichern Sie sie im Cache direkt aus dem Cache. Dies kann die Anzahl der Interaktionen mit der Datenbank reduzieren, was die Leistung des Programms verbessern kann.

    Anwendbarkeit des Caches: häufig abgefragt aber nicht häufig geändert (z. B. Provinzen, Städte, Kategoriedaten), die Genauigkeit der Daten hat kaum Einfluss auf das Endergebnis

    Nicht zum Caching geeignet: sich häufig ändernde Daten, sensible Daten (z. B.: Börsenkurse, Wechselkurse der Banken, Das Geld auf der Bankkarte) usw. Es ist im Lieferumfang enthalten (keine Konfiguration erforderlich) und kann nicht deinstalliert werden (es ist in Ordnung, wenn Sie es nicht verwenden möchten). Der Lebenszyklus des Caches der ersten Ebene stimmt mit sqlSession überein.

    Level-2-Cache: Es ist der Cache von SqlSessionFactory. Solange die von derselben SqlSessionFactory erstellte SqlSession den Inhalt des Caches der zweiten Ebene gemeinsam nutzt, kann sie den Cache der zweiten Ebene betreiben. Wenn wir den Second-Level-Cache verwenden möchten, müssen wir ihn manuell selbst aktivieren (Konfiguration ist erforderlich).

    Verwendung des Second-Level-Cache

    1 Aktivieren Sie den Second-Level-Cache in der Kernkonfigurationsdatei von mybatis

        <!--**因为 cacheEnabled 的取值默认就为 true**,所以这一步可以省略不配置。为 true 代表开启二级缓存;为 false 代表不开启二级缓存。  -->
    <settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>

    2 Dao-Zuordnungsdatei Konfigurieren Sie die Verwendung des Caches der zweiten Ebene

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
            PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.itheima.dao.UserDao">
        <!--配置二级缓存-->
        <cache/>
       
        <select id="findAll" resultType="user">
            select * from t_user
        </select>
     
        <delete id="deleteById" parameterType="int">
            delete from t_user where uid=#{id}
        </delete>
    </mapper>

     3. Die Pojo-Klasse, die für den Cache der zweiten Ebene verwendet werden soll, muss die serialisierbare Schnittstelle

    public class User implements Serializable {
        private int uid;
        private String username;
        private String sex;
        private Date birthday;
        private String address;
        // 省略setter,getter,构造...等方法
    }

    4 implementieren Verwendung des Caches der zweiten Ebene Nach dem obigen Test haben wir festgestellt, dass zwei Abfragen ausgeführt wurden. Nach der Ausführung der ersten Abfrage haben wir den Cache der ersten Ebene deaktiviert. Als wir die zweite Abfrage ausgeführt haben, haben wir festgestellt, dass keine SQL-Anweisung an die Datenbank ausgegeben wurde Die Daten können derzeit nur aus dem von uns genannten Level-2-Cache stammen.

    5. Test zum Ausschalten des Second-Level-Cache

    -Testcode

    @Test
          public void testFindAll() throws Exception{
              // 1.加载mybatis核心配置文件
              InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");
     
              // 2.创建SqlSessionFactoryBuilder对象
              SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
     
              // 3.构建SqlSessionFactory对象
              SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
     
              // 4.获取SqlSession对象
              SqlSession sqlSession = sqlSessionFactory.openSession();
     
              // 5.获得dao接口的代理对象
              UserDao userDao = sqlSession.getMapper(UserDao.class);
     
              // 6.执行sql语句,得到结果
              List<User> list = userDao.findAll();
              for (User user : list) {
                  System.out.println("user = " + user);
              }
              sqlSession.close();//清除一级缓存
     
              System.out.println("分割线----------------------------------");
     
              SqlSession sqlSession2 = sqlSessionFactory.openSession();
              UserDao userDao2 = sqlSession2.getMapper(UserDao.class);
              List<User> userList2 = userDao2.findAll();
              for (User user : userList2) {
                  System.out.println(user);
              }
              // 7.释放资源
              sqlSession2.close();
          }

    -Testergebnis

    # 🎜🎜#

    Nach dem obigen Test stellten wir fest, dass zwei Abfragen ausgeführt wurden, und nachdem wir die erste Abfrage ausgeführt hatten, schlossen wir den Cache der ersten Ebene, schlossen den Cache der zweiten Ebene und führten dann aus Bei der zweiten Abfrage stellten wir fest, dass eine SQL-Anweisung an die Datenbank ausgegeben wurde, sodass die Daten zu diesem Zeitpunkt aus der Datenbank und nicht aus dem Cache stammten.

    Das obige ist der detaillierte Inhalt vonSo verwenden Sie den Second-Level-Cache von Mybatis in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen