Heim  >  Artikel  >  Java  >  Beispiel-Tutorial einer SQL-Zuordnungsdatei

Beispiel-Tutorial einer SQL-Zuordnungsdatei

零下一度
零下一度Original
2017-07-17 15:15:581622Durchsuche

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;
    }
}

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>

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());
        }
}

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>

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());
        }

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语句
select * from student,grade

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>

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>

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;

   。。。。。省略封装

 <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>
    <!--这里使用了自动匹配-->
<select id="getAllStudent" resultMap="studentMap"> SELECT * FROM student,grade WHERE student.stuGrade=grade.gradeId</select>

测试类里直接调用即可

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

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

javaBean

  private int gradeId;private String gradeName;private List<student> gatStudent;
 <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>
 <!--查询对应年级的student-->
    <select id="getAll" resultMap="gradeMap">   select * from student,grade where stuGrade = gradeId and gradeId=1
    </select>

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!

Stellungnahme:
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