Heim Java javaLernprogramm Beispiel-Tutorial einer SQL-Zuordnungsdatei

Beispiel-Tutorial einer SQL-Zuordnungsdatei

Jul 17, 2017 pm 03:15 PM
文件 映射

SQL-Zuordnungsdatei

Die wahre Stärke von MyBatis liegt in der Zuordnungsanweisung. Vergleicht man den Preis mit JDBC und gleichwertigen Funktionen, sparen Mapping-Dateien viel Code. MyBatis ist so konzipiert, dass es sich auf SQL konzentriert.

SQL-Zuordnungsdateien verfügen über die folgenden Elemente der obersten Ebene: (in der Reihenfolge)

cache konfiguriert den Cache für einen bestimmten Namespace.

cache-ref verweist auf die Cache-Konfiguration aus anderen Namespaces.

resultMap ist das komplexeste und leistungsfähigste Element, das verwendet wird, um zu beschreiben, wie Sie Ihre Objekte aus dem Datenbank-Ergebnissatz laden.

parameterMap ist veraltet! Parameterzuordnung im Old-School-Stil. Inline-Parameter werden bevorzugt. Dieses Element wird möglicherweise in Zukunft entfernt.

sql ist ein wiederverwendbarer SQL-Block und kann auch von anderen Anweisungen referenziert werden.

Mapping-Insert-Anweisung einfügen.

Update-Mapping-Update-Anweisung.

Anweisungen zum Löschen von Karten löschen.

Wählen Sie die Mapping-Abfrageanweisung aus.

MyBatis ist so konzipiert, dass es sich auf SQL konzentriert und es von gewöhnlichen Methoden fernhält.

SQL-Zuordnungsdateien haben einige Elemente der obersten Ebene (in der Reihenfolge, in der sie definiert werden sollten):

>Mapper: der Stammelementknoten der Zuordnungsdatei, mit nur Ein Attribut Der Namespace-Namespace wird zur Unterscheidung verschiedener Mapper verwendet. Er ist global eindeutig und der vollständige Name der DAO-Schnittstelle ist an den Namespace gebunden, d. h. schnittstellenorientierte Programmierung. Der Mapper entspricht hier der Implementierungsklasse der Schnittstelle.

Cache – Konfigurieren Sie den Cache für den angegebenen Namespace.

cache-ref – Referenzieren Sie die Cache-Konfiguration aus anderen Namespaces.

resultMap – Das komplexeste und leistungsfähigste Element, das verwendet wird, um zu beschreiben, wie Sie Ihre Objekte aus dem Datenbank-Ergebnissatz laden.

parameterMap – Veraltet! Parameterzuordnung im Old-School-Stil. Inline-Parameter werden bevorzugt. Dieses Element wird möglicherweise in Zukunft entfernt. Es wird hier nicht aufgezeichnet.

sql – SQL-Block, der von anderen Anweisungen wiederverwendet und referenziert werden kann.

insert – Mapping-Insert-Anweisung

update – Mapping-Update-Anweisung

delete – Mapping-Delete-Anweisung

select – Mapping-Query-Anweisung

1: Verwenden Sie „Auswahl“, um die bedingte Abfrage abzuschließen.

Verwenden Sie die Tool-Idee und die MySQL-Datenbank.

Erstellen Sie eine Entitätsklasse.

public class student {private int stuId;private String  stuName;private grade getGrade;private  int stuAge;public grade getGetGrade() {return getGrade;
    }public void setGetGrade(grade getGrade) {this.getGrade = getGrade;
    }public int getStuAge() {return stuAge;
    }   public student(int id,String name){

   }   public student(){}public void setStuAge(int stuAge) {this.stuAge = stuAge;
    }public int getStuId() {return stuId;
    }public void setStuId(int stuId) {this.stuId = stuId;
    }public String getStuName() {return stuName;
    }public void setStuName(String stuName) {this.stuName = stuName;
    }
}
Nach dem Login kopieren

Verwenden Sie „select“, um die bedingte Abfrage abzuschließen

1: Konfigurieren Sie zunächst den Mapper für die Verwendung von resultType

<!--模糊查询   使用resultType返回结果集-->    
    <select id="getAllStudentByLike" parameterType="String" resultType="stu">* from student where stuName like CONCAT('%',#{stuName},'%'</select>
Nach dem Login kopieren

Testklasse

 public  void Test() throws IOException {

        studentDao dao = MyBatis.getSessionTwo().getMapper(studentDao.class);
        List<student> list = dao.getAllStudentByLike("z");for (student item:list) {
            System.out.println("----------"+item.getStuName());
        }
}
Nach dem Login kopieren

Zusätzlich zu JavaBean umfassen die von ParameterType unterstützten komplexen Typen auch den Map-Typ

, also den Mapper ändern

 <!--模糊查询-->
    <select id="getAllStudentByLike" parameterType="Map" resultType="stu">select * from student where stuName like CONCAT('%',#{stuName},'%')</select>
Nach dem Login kopieren

Erstellen Sie dann eine HashMap-Sammlung in der Testklasse und verwenden Sie sie direkt als Methodenparameter

studentDao dao = MyBatis.getSessionTwo().getMapper(studentDao.class);
        Map<String,String> userMap = new HashMap<String, String>();
        userMap.put("stuName","z");
        List<student> list = dao.getAllStudentByLike(userMap);for (student item:list) {
            System.out.println("----------"+item.getStuName());
        }
Nach dem Login kopieren

Allerdings ist der Schlüsselwert von Die Kartensammlung muss mit dem Feldnamen in der Klasse identisch sein.

Zwei: Verwenden Sie resultMap, um eine Zwei-Tabellen-Abfrage abzuschließen.

Wenn beispielsweise die Schülertabelle mit der Primärschlüssel-ID der Klassentabelle verknüpft ist und Sie resultType verwenden, werden Sie kann nur seine ID anzeigen, aber in der Praxis konzentriert man sich oft auf den Klassennamen. Alle müssen resultMap verwenden, um benutzerdefinierte Ergebnisse zuzuordnen.

<resultMap id="studentMap" type="entity.student">
<id property="stuId" column="stuId"></id>
        <result property="stuName" column="stuName"></result>
        <result property="gradeName" column="gradeName">
       
    </resultMap>

//sql语句
Nach dem Login kopieren
select * from student,grade
Nach dem Login kopieren

resultType stellt direkt den Rückgabetyp dar, einschließlich Grundtypen und komplexer Datentypen.

resultMap ist ein Verweis auf die externe resultMap, die dem entspricht ID der resultMap Gibt an, welcher resultMap das zurückgegebene Ergebnis zugeordnet ist. : Seine Anwendungsszenarien sind: Datenbankfeldinformationen stimmen nicht mit Objektattributen überein oder es müssen komplexe gemeinsame Abfragen durchgeführt werden, um die Zuordnungsergebnisse frei zu steuern.

Darüber hinaus sind resultType und resultMap im Select-Element von MyBatis im Wesentlichen gleich, beide sind Kartendatenstrukturen. Aber beides kann nicht gleichzeitig existieren.

Drei: Automatische Zuordnungsebene von resultMap verwenden

MyBatis ist in drei Zuordnungsebenen unterteilt

>KEINE: Automatische Zuordnung deaktivieren

>TEILWEISE :(Standard): Alle Attribute automatisch abgleichen, außer denen mit interner Verschachtelung (Zuordnung, Sammlung)

>FULL: Alle Attribute automatisch abgleichen

AutoMappingBehavior einstellen

 <settings>   <!--设置resultMap的自动映射级别为Full(自动匹配所有)--><setting name="autoMappingBehavior" value="FULL" />   <!--FULL要大写··--> </settings>
Nach dem Login kopieren

Wenn Sie den Wert von autoMappingBehavior auf FULL setzen, müssen die Knoten unter resultMap nicht konfiguriert werden. Sie werden automatisch entsprechend der Datenbank abgeglichen

Vier : Verwenden Sie „Update“, um die Änderung abzuschließen

 <update id="update">update student set stuName=#{0} where stuId=#{1}</update>
Nach dem Login kopieren

Hier ist eine einfachere Möglichkeit, Platzhalter als Parameter zu verwenden. Geben Sie einfach die Parameter ein direkt in der Testklasse.

Fünftens: Verwenden Sie die Attributzuordnung, die komplexe Typen zuordnet.

Das vorherige Ergebnis kann nur einem bestimmten „einfachen Typ“-Attribut zugeordnet werden JavaBean, Basisdatentyp und Verpackungsklasse usw./

Aber wenn Sie Eigenschaften komplexer Typen zuordnen möchten, müssen Sie Assoziationen verwenden. Komplexe Klassen: Das heißt, es gibt ein anderes JavaBean in einem JavaBean, aber eine Assoziation Behandelt nur Eins-zu-Eins-Beziehungen

        stuAge;

   。。。。。省略封装
Nach dem Login kopieren

 <resultMap id="studentMap" type="entity.student">
       <!-- <id property="stuId" column="stuId"></id>
        <result property="stuName" column="stuName"></result>-->
        <!--关联另一个 属性-->
        <association property="getGrade" javaType="grade">
       <!-- <id property="gradeId" javaType="Integer" column="gradeId"></id>
       <result property="gradeName" javaType="String" column="gradeName"></result>-->
        </association>
    </resultMap>
    <!--这里使用了自动匹配-->
Nach dem Login kopieren
<select id="getAllStudent" resultMap="studentMap"> SELECT * FROM student,grade WHERE student.stuGrade=grade.gradeId</select>
Nach dem Login kopieren

测试类里直接调用即可

六:前面说到association仅处理一对一的管理关系

    如果要处理一对多的关系,则需要使用collection,它与 association元素差不多,但它映射的属性是一个集合列表,即javaBean内部嵌套一个复杂数据类型属性。

javaBean

  private int gradeId;private String gradeName;private List<student> gatStudent;
Nach dem Login kopieren
 <resultMap id="gradeMap" type="grade">
        <!--<id property="gradeId" column="gradeId"></id>
        <result property="gradeName" column="gradeName"></result>-->
        <collection property="gatStudent" ofType="stu">
             <!-- <id property="stuId" column="stuId"></id>
              <result property="stuName" column="stuName"></result>-->
        </collection>
    </resultMap>
Nach dem Login kopieren
 <!--查询对应年级的student-->
    <select id="getAll" resultMap="gradeMap">   select * from student,grade where stuGrade = gradeId and gradeId=1
    </select>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonBeispiel-Tutorial einer SQL-Zuordnungsdatei. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

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 vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie kann man abgelaufene WeChat-Dateien wiederherstellen? Können abgelaufene WeChat-Dateien wiederhergestellt werden? Wie kann man abgelaufene WeChat-Dateien wiederherstellen? Können abgelaufene WeChat-Dateien wiederhergestellt werden? Feb 22, 2024 pm 02:46 PM

Öffnen Sie WeChat, wählen Sie „Einstellungen“ in „Ich“, wählen Sie „Allgemein“ und dann „Speicherplatz“, wählen Sie „Verwaltung“ unter „Speicherplatz“, wählen Sie die Konversation aus, in der Sie Dateien wiederherstellen möchten, und wählen Sie das Ausrufezeichen-Symbol aus. Tutorial Anwendbares Modell: iPhone13 System: iOS15.3 Version: WeChat 8.0.24 Analyse 1 Öffnen Sie zunächst WeChat und klicken Sie auf der Seite „Mein“ auf die Option „Einstellungen“. 2 Suchen Sie dann auf der Einstellungsseite nach „Allgemeine Optionen“ und klicken Sie darauf. 3Klicken Sie dann auf der allgemeinen Seite auf Speicherplatz. 4 Klicken Sie anschließend auf der Seite „Speicherplatz“ auf „Verwalten“. 5Wählen Sie abschließend die Konversation aus, in der Sie Dateien wiederherstellen möchten, und klicken Sie rechts auf das Ausrufezeichen-Symbol. Ergänzung: WeChat-Dateien verfallen in der Regel nach einigen Tagen. Wenn die von WeChat empfangene Datei nicht angeklickt wurde, löscht das WeChat-System sie nach 72 Stunden.

Fotos können diese Datei nicht öffnen, da das Format nicht unterstützt wird oder die Datei beschädigt ist Fotos können diese Datei nicht öffnen, da das Format nicht unterstützt wird oder die Datei beschädigt ist Feb 22, 2024 am 09:49 AM

Unter Windows ist die Fotos-App eine bequeme Möglichkeit, Fotos und Videos anzuzeigen und zu verwalten. Über diese Anwendung können Benutzer problemlos auf ihre Multimediadateien zugreifen, ohne zusätzliche Software installieren zu müssen. Allerdings kann es bei Benutzern manchmal zu Problemen kommen, wie z. B. der Fehlermeldung „Diese Datei kann nicht geöffnet werden, da das Format nicht unterstützt wird“ bei der Verwendung der Fotos-App oder einer Dateibeschädigung beim Versuch, Fotos oder Videos zu öffnen. Diese Situation kann für Benutzer verwirrend und unbequem sein und erfordert einige Untersuchungen und Korrekturen, um die Probleme zu beheben. Benutzern wird die folgende Fehlermeldung angezeigt, wenn sie versuchen, Fotos oder Videos in der Fotos-App zu öffnen. Fotos können diese Datei leider nicht öffnen, da das Format oder die Datei derzeit nicht unterstützt wird

Können Dateien im Tmp-Format gelöscht werden? Können Dateien im Tmp-Format gelöscht werden? Feb 24, 2024 pm 04:33 PM

TMP-Formatdateien sind ein temporäres Dateiformat, das normalerweise von einem Computersystem oder Programm während der Ausführung generiert wird. Der Zweck dieser Dateien besteht darin, temporäre Daten zu speichern, um die ordnungsgemäße Ausführung des Programms zu unterstützen oder die Leistung zu verbessern. Sobald die Programmausführung abgeschlossen ist oder der Computer neu gestartet wird, werden diese tmp-Dateien häufig nicht mehr benötigt. Daher sind Dateien im Tmp-Format grundsätzlich löschbar. Darüber hinaus kann das Löschen dieser tmp-Dateien Festplattenspeicher freigeben und den normalen Betrieb des Computers gewährleisten. Bevor wir jedoch Dateien im Tmp-Format löschen, müssen wir dies tun

Was tun, wenn der Fehlercode 0x80004005 angezeigt wird? Der Editor zeigt Ihnen, wie Sie den Fehlercode 0x80004005 beheben können. Was tun, wenn der Fehlercode 0x80004005 angezeigt wird? Der Editor zeigt Ihnen, wie Sie den Fehlercode 0x80004005 beheben können. Mar 21, 2024 pm 09:17 PM

Wenn Sie einen Ordner auf Ihrem Computer löschen oder dekomprimieren, wird manchmal das Dialogfeld „Fehler 0x80004005: Nicht spezifizierter Fehler“ angezeigt. Wie können Sie diese Situation lösen? Es gibt tatsächlich viele Gründe, warum der Fehlercode 0x80004005 angezeigt wird, aber die meisten davon werden durch Viren verursacht. Wir können die DLL erneut registrieren, um das Problem zu lösen. Nachfolgend erklärt Ihnen der Editor die Erfahrung beim Umgang mit dem Fehlercode 0x80004005 . Einige Benutzer erhalten bei der Verwendung ihres Computers den Fehlercode 0X80004005. Der Fehler 0x80004005 wird hauptsächlich dadurch verursacht, dass der Computer bestimmte Dynamic Link Library-Dateien nicht korrekt registriert oder dass eine Firewall keine HTTPS-Verbindungen zwischen dem Computer und dem Internet zulässt. Wie wäre es also?

So installieren Sie GHO-Dateien So installieren Sie GHO-Dateien Feb 19, 2024 pm 10:06 PM

Die GHO-Datei ist eine GhostImage-Image-Datei, die normalerweise zum Sichern der gesamten Festplatten- oder Partitionsdaten in einer Datei verwendet wird. In bestimmten Fällen müssen wir diese GHO-Datei erneut auf der Festplatte installieren, um die Festplatte oder Partition in ihren vorherigen Zustand zurückzusetzen. Im Folgenden wird erläutert, wie die GHO-Datei installiert wird. Vor der Installation müssen wir zunächst die folgenden Tools und Materialien vorbereiten: Entitäts-GHO-Datei: Stellen Sie sicher, dass Sie über eine vollständige GHO-Datei verfügen, die normalerweise das Suffix .gho hat und eine Sicherung enthält

Wie übertrage ich Dateien von Quark Cloud Disk auf Baidu Cloud Disk? Wie übertrage ich Dateien von Quark Cloud Disk auf Baidu Cloud Disk? Mar 14, 2024 pm 02:07 PM

Quark Netdisk und Baidu Netdisk sind derzeit die am häufigsten verwendete Netdisk-Software zum Speichern von Dateien. Wenn Sie die Dateien in Quark Netdisk auf Baidu Netdisk speichern möchten, wie gehen Sie vor? In dieser Ausgabe hat der Herausgeber die Tutorial-Schritte zum Übertragen von Dateien vom Quark Network Disk-Computer auf die Baidu Network Disk zusammengestellt. Werfen wir einen Blick auf die Bedienung. Wie speichere ich Quark-Netzwerkfestplattendateien auf einer Baidu-Netzwerkfestplatte? Um Dateien von Quark Network Disk auf Baidu Network Disk zu übertragen, müssen Sie zunächst die erforderlichen Dateien von Quark Network Disk herunterladen, dann den Zielordner im Baidu Network Disk-Client auswählen und ihn öffnen. Ziehen Sie dann die von Quark Cloud Disk heruntergeladenen Dateien per Drag & Drop in den vom Baidu Cloud Disk-Client geöffneten Ordner oder verwenden Sie die Upload-Funktion, um die Dateien zu Baidu Cloud Disk hinzuzufügen. Überprüfen Sie nach Abschluss des Uploads unbedingt, ob die Datei erfolgreich in Baidu Cloud Disk übertragen wurde. Das ist es

Unterschiedliche Verwendung von Schrägstrichen und Backslashes in Dateipfaden Unterschiedliche Verwendung von Schrägstrichen und Backslashes in Dateipfaden Feb 26, 2024 pm 04:36 PM

Ein Dateipfad ist eine Zeichenfolge, die vom Betriebssystem verwendet wird, um eine Datei oder einen Ordner zu identifizieren und zu finden. In Dateipfaden gibt es zwei gängige Symbole zur Trennung von Pfaden, nämlich den Schrägstrich (/) und den Backslash (). Diese beiden Symbole haben in verschiedenen Betriebssystemen unterschiedliche Verwendungen und Bedeutungen. Der Schrägstrich (/) ist ein häufig verwendetes Pfadtrennzeichen in Unix- und Linux-Systemen. Auf diesen Systemen beginnen Dateipfade im Stammverzeichnis (/) und werden durch Schrägstriche zwischen den einzelnen Verzeichnissen getrennt. Zum Beispiel der Pfad /home/user/Docume

Was ist die Datei hiberfil.sys? Kann hiberfil.sys gelöscht werden? Was ist die Datei hiberfil.sys? Kann hiberfil.sys gelöscht werden? Mar 15, 2024 am 09:49 AM

Vor kurzem haben viele Internetnutzer den Herausgeber gefragt: Was ist die Datei hiberfil.sys? Kann hiberfil.sys viel Speicherplatz auf Laufwerk C beanspruchen und gelöscht werden? Der Editor kann Ihnen mitteilen, dass die Datei hiberfil.sys gelöscht werden kann. Werfen wir einen Blick auf die Details unten. hiberfil.sys ist eine versteckte Datei im Windows-System und auch eine System-Ruhezustandsdatei. Es wird normalerweise im Stammverzeichnis des Laufwerks C gespeichert und seine Größe entspricht der Größe des installierten Speichers des Systems. Diese Datei wird verwendet, wenn sich der Computer im Ruhezustand befindet, und enthält die Speicherdaten des aktuellen Systems, damit dieser bei der Wiederherstellung schnell wieder in den vorherigen Zustand versetzt werden kann. Da seine Größe der Speicherkapazität entspricht, nimmt er möglicherweise mehr Festplattenspeicher ein. hiber

See all articles