Mybatisフレームワーク----->(5)Mybatisパッケージの出力とファジークエリの結果を深く理解する

Mybatisパッケージ出力の結果の1つの深い理解

1、resultType

  • SQLステートメントの実行によって取得されたResultSet変換のタイプを参照します。ここで使用される変換タイプは次のとおりです。
    (1)完全修飾名:com.hcz.entity.Student
    (2)タイプエイリアス:たとえば、java.lang.Integerエイリアスはint
    (3)カスタムエイリアス:mybatisメイン構成ファイルで定義されています。<を使用してください。typeAlias>エイリアスを定義すると、resultTypeでカスタムエイリアスを使用できます

エイリアスを定義する2つの方法は次のとおりです。

  • 最初の方法:

  • type:カスタムタイプの完全修飾名

  • エイリアス:エイリアス(短く、覚えやすい)

<typeAlias type="com.hcz.entity.Student" alias="stu"/>
<typeAlias type="com.hcz.vo.ViewStudent" alias="vstu"/>
  • 2番目の方法:
  • <パッケージ> nameはパッケージ名であり、このパッケージ内のすべてのクラスの場合、[classname]はエイリアスです。
<package name="com.hcz.entity"/>
<package name="com.hcz.vo"/>

注:戻り値がコレクションの場合は、コレクションリスト自体ではなく、コレクションに含まれているタイプでもある必要があります。以下に示すように:

ここに画像の説明を挿入

実装の原則:
1。MybatisはSQLステートメントを実行し、次にmybatisはクラスのパラメーターなしの構築メソッドを呼び出してオブジェクトを作成します。
2. Mybatisは、setメソッドを呼び出して、ResultSetの指定された列値を同じ名前の属性に割り当てます。

マッピングファイル:
<select id="selectMultiPosition" resultType="com.bjpowernode.domain.Student">
       select id,name, email,age from student
</select>
次のjdbcコードとほぼ同等です。
ResultSet rs = executeQuery(" select id,name  from student" )
while(rs.next()){
    
    
    Student  student = new Student();
	student.setId(rs.getInt("id"));
	student.setName(rs.getString("name"));
	studentList.add(student);
}
ここでは、SQL実行後の列データがJavaオブジェクトStudentに変換されますここに画像の説明を挿入
(1)シンプルタイプ
  • インターフェイスでメソッドを定義します
int countStudent();
  • マッピングファイル
<!--返回int类型数值-->
<select id="countStudent" resultType="int">
    select count(*) from student
</select>
  • テスト方法を定義する
@Test
public void testRetunInt(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    int count = dao.countStudent();
    System.out.println("学生总人数:"+ count);
}
(2)オブジェクトタイプ
  • インターフェイスでメソッドを定義します
List<Student> selectMulitParam(@Param("myname") String name,
                                @Param("myage") Integer age);
  • マッピングファイル
<select id="selectMulitParam" resultType="Student">
    select * from student where name=#{myname} or age=#{myage}
</select>
  • テスト方法を定義する
@Test
public void testSelectMulitParam(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    List<Student> studentList = dao.selectMulitParam("李四", 28);
    for (Student student: studentList){
    
    
        System.out.println("学生="+student);
    }
}
(3)マップタイプ
  • 戻り値はmapです。ここで、列名(id、name、age)はマップのキー値であり、列値(1002、Zhang San、34はマップの値)です。
  • 複数行ではなく、1行のレコードのみを返すことができます
  • インターフェイスでメソッドを定義します
Map<Object,Object> selectReturnMap(int id);
  • マッピングファイル
<select id="selectReturnMap" resultType="java.util.HashMap">
    select * from student where id=#{sid}
</select>
  • テスト方法を定義する
public void testReturnMap(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    Map<Object,Object> retMap = dao.selectReturnMap(1002);
    System.out.println("查询结果是 Map:"+retMap);
}

2、resultMap

  • ResultMapは、列名とJavaオブジェクトの属性の間の対応を指定する結果マップです。指定された属性に列値を割り当てる方が柔軟性があります。これは、列名とJavaオブジェクトの属性名の場合によく使用されます。一貫性がない

使用法:
(1)最初にresultMapを定義し、列名と属性の間の対応を指定します
(2)In <選択する> resultTypeをresultMapに置き換えます

  • インターフェイスでメソッドを定義します
List<Student> selectUseResultMap(QueryParam param);
  • マッピングファイル
	<resultMap id="studentMap" type="Student">
        <!-- 主键字段使用 id -->
        <id column="id" property="id" />
        <!--非主键字段使用 result-->
        <result column="name" property="name"/>
        <result column="email" property="email" />
        <result column="age" property="age" />
    </resultMap>
        <!--resultMap: resultMap 标签中的 id 属性值-->
    <select id="selectUseResultMap" resultMap="studentMap">
        select * from student where name=#{paramName} or
        age=#{paramAge}
    </select>

解決策:
(1)id:valueは、<select>で使用されるカスタムの一意の名前です。
(2)type:変換するJavaオブジェクトの完全修飾名またはエイリアス
(3)column:データベース内の列名
(4)プロパティ:Javaオブジェクトのプロパティ名
(5)resultMap:<resultMap>のID値

  • テスト方法を定義する
@Test
public void testSelectUseResultMap(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    QueryParam param = new QueryParam();
    param.setParamName("李四");
    param.setParamAge(28);
    List<Student> stuList = dao.selectUseResultMap(param);
    stuList.forEach( stu -> System.out.println(stu));
}

3.エンティティクラスの属性名と列名の2つの処理方法が異なります

(1)<resultMap>を使用します
  • インターフェイスでメソッドを定義します
List<MyStudent> selectMyStudent();
  • マッピングファイル
<resultMap id="myStudentMap" type="MyStudent">
    <id column="id" property="stuid" />
    <result column="name" property="stuname"/>
    <result column="email" property="stuemail" />
    <result column="age" property="stuage" />
</resultMap>

<select id="selectMyStudent" resultMap="myStudentMap">
    select * from student
</select>
  • テスト方法を定義する
@Test
public void testSelectMyStudent(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    List<MyStudent> stuList = dao.selectMyStudent();
    stuList.forEach( stu -> System.out.println("MyStudent="+stu));
}
(2)列エイリアスと<resultType>を使用します

reultTypeのデフォルトの原則は次のとおりです。同じ名前の列値が同じ名前の属性に割り当てられ、ここでは列エイリアス(Javaオブジェクトの属性名)が使用されます。

  • インターフェイスでメソッドを定義します
List<MyStudent> selectDiffColProperty();
  • マッピングファイル
<select id="selectDiffColProperty" resultType="MyStudent">
    select id as stuid,name as stuname,email as stuemail,age as stuage
    from student
</select>
  • テスト方法を定義する
@Test
public void testSelectDiffColProperty(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    List<MyStudent> stuList = dao.selectDiffColProperty();
    stuList.forEach( stu -> System.out.println("MyStudent="+stu));
}

:resultTypeとresultMapを一緒に使用することはできません。選択できるのは、2つのうちの1つだけです。

2つのようなファジークエリ

(1)Javaコードのクエリデータに「%xxx%」を追加します(より便利)

  • インターフェイスでメソッドを定義します
List<Student> selectLikeOne(String name);
  • マッピングファイル
<select id="selectLikeOne" resultType="Student">
    select id,name,email,age from student where name like #{name }
</select>
  • テスト方法を定義する
@Test
public void testSelectLikeOne(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    //准备好like的内容
    String name="%李%";
    List<Student> stuList = dao.selectLikeOne(name);
    stuList.forEach( stu -> System.out.println("OnelikeStudent="+stu));
}

(2)マッピングファイルのSQLステートメントの条件付き位置に "%"#{xxx} "%"を追加します

  • インターフェイスでメソッドを定義します
List<Student> selectLikeTow(String name);
  • マッピングファイル
<select id="selectLikeTow" resultType="Student">
    select id,name,email,age from student where name like "%" #{name} "%"
</select>
  • テスト方法を定義する
@Test
public void testSelectLikeTow(){
    
    
    SqlSession sqlSession = MyBatisUtil.getSqlSession();
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    String name="李";
    List<Student> stuList = dao.selectLikeTow(name);
    stuList.forEach( stu -> System.out.println("TowlikeStudent="+stu));
}

三、思考の概要

ここに画像の説明を挿入

不備があれば訂正してください!

おすすめ

転載: blog.csdn.net/hcz666/article/details/113098063