suchen
HeimJavajavaLernprogrammSo verwenden Sie den Second-Level-Cache von Mybatis in Java

    Ü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:亿速云. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heißer Artikel

    R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
    1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Beste grafische Einstellungen
    1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
    Will R.E.P.O. Crossplay haben?
    1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    MinGW – Minimalistisches GNU für Windows

    MinGW – Minimalistisches GNU für Windows

    Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

    SecLists

    SecLists

    SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor