MyBatis のエンティティ Bean のデータベースフィールドと属性間の不一致に対処する方法

Y2J
リリース: 2018-05-18 17:10:18
オリジナル
7287 人が閲覧しました

この記事では、MyBatis の使い方、追加、削除、変更、確認方法と、データベースフィールドとエンティティフィールドの不一致への対処方法を主に紹介します。データベースのフィールドとエンティティ Bean が矛盾しています

以前のデータベース パーソン名 フィールドは name で、PersonBean の属性も name ですが、後でデータベース内で user_name に変更されました。

方法 1: エイリアスを作成するSQL ステートメントのフィールドを通じて、エイリアスはエンティティの

object

属性と一致しています

SELECT id,user_name as name,sex,age from person
<select id="find" resultType="com.luogg.domain.Person">
  SELECT id,user_name as name,sex,age from person
</select>
ログイン後にコピー
方法 2: mybatis の最も強力な点: reslutMap オブジェクト

中間の reslutMap タグを追加し、変更しますselectタグのresultTypeをresultMapに設定し、resultMapタグのidに対応させます。結果セット: resultType基本型、int、string、person、

resultMapは

<!--配置命名空间,命名空间+ .id 是唯一的sql语句标示符-->
<mapper namespace="com.luogg.mapper.PersonMapper">
 <!--中介,当数据库字段和实体bean对象属性不一致时,做一个对应关系-->
 <resultMap id="personRM" type="com.luogg.domain.Person">
  <!--主键映射-->
  <id property="id" column="ID"></id>
  <!--普通字段,property指实体属性,column结果集的字段名称,一致的字段可以不写-->
  <result property="name" column="USER_NAME"></result>
 </resultMap>
 <!--查询所有数据,参数有id,resultType结果集,parameterType参数-->
 <!--注意 : sql语句中如果有要填写集合的,比如查询所有数据,返回一个Person的结果集,那么resultType参数直接写 路径+集合的类型
  比如: 返回一个Person集合,那么就填写Person Bean所在的路径+Person-->
 <select id="find" resultMap="personRM">
  SELECT * from person
 </select>
 <!--通过ID查询数据,当有查询条件时,需要写parameterType,返回结果集仍然是Person, #{id}或者${id}都可以-->
 <select id="selById" parameterType="int" resultType="com.luogg.domain.Person">
  SELECT * FROM person WHERE id = #{id}
 </select>
</mapper>
ログイン後にコピー

Mybatisの追加の中間ラベル用に存在します。 、削除、変更、確認

新しい個人情報

まず、データベースフィールドuser_name、個人エンティティ属性にinsertタグを追加します。名前が矛盾している場合は、それを区別してから、TestMybatisにコードを記述します。

パッケージテスト;

import com.luogg.domain.Person;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
/**
 * Created by luogg on 2017/2/17.
 */
public class TestMybatis {
 //SqlSessionFactory为线程安全的
 private SqlSessionFactory factory;
 @Before
 public void init() throws IOException {
  String resource = "sqlMapConfig.xml";
  InputStream is = Resources.getResourceAsStream(resource);
  factory = new SqlSessionFactoryBuilder().build(is);
 }
 @Test //查询所有
 public void findAll() throws IOException {
  /**
   * 测试数据库的连接
   * 1.定义一个String类型的变量resource,指向刚才配置的连接数据库的xml文件
   * 2.创建一个输入流,来读取我们的数据库配置文件
   * 3.输入流创建工厂.
   * 4.有了工厂之后open工厂
   * 5.通过session访问配置文件中的sql语句
   */
  SqlSession session = factory.openSession();
  //如何访问PersonMapper.xml中的sql语句呢? 命名空间+ .id
  List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.find");
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }
 @Test //通过ID查询人员信息
 public void selById(){
  SqlSession session = factory.openSession();
  Person p = session.selectOne("com.luogg.mapper.PersonMapper.selById",1);
  System.out.println(p);
 }
 @Test //添加人员信息
 public void add(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luogg");
  p.setAge(22);
  p.setSex(1);
  int i = session.insert("com.luogg.mapper.PersonMapper.insert",p);
  session.commit();
  if(i==1){
   System.out.print("添加人员成功");
  }
 }
}
ログイン後にコピー

人事情報を変更し、レコードの総数をクエリ

prsonMapper.xmlファイル

<!--修改成员信息-->
 <update id="update" parameterType="com.luogg.domain.Person">
  UPDATE person SET user_name=#{name},age=#{age} WHERE id=#{id}
 </update>
 <!--查询总的记录-->
 <select id="count" resultType="int">
  SELECT COUNT(*) FROM person
 </select>
ログイン後にコピー

TestMybatis.javaファイル

@Test //修改人员信息
 public void updatePer(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luoggg");
  //p.setSex(1);
  p.setAge(23);
  int i = session.update("com.luogg.mapper.PersonMapper.update",p);
  session.commit();
  if(i==1){
   System.out.print("修改信息成功");
  }
 }
 @Test //查询总的记录条数
 public void selCount(){
  SqlSession session = factory.openSession();
  int i = session.selectOne("com.luogg.mapper.PersonMapper.count");
  System.out.println(i);
 }
ログイン後にコピー

条件付きクエリ

条件に基づくクエリ

<!--带条件查询-->
 <select id="selByL" parameterType="map" resultMap="personRM">
  SELECT <include refid="cols"/> FROM person
  where user_name like #{name}
  AND sex=#{sex}
 </select>
@Test //带条 件查询
 public void selByL(){
  SqlSession session = factory.openSession();
  Map<String,Object> map = new HashMap<String, Object>();
  map.put("name","luo%");
  map.put("sex",1);
  List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.selByL",map);
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }
ログイン後にコピー

[関連する推奨事項]

1.


特別な推奨事項

: 「php プログラマー ツールボックス」V0.1 バージョンのダウンロード2 Java 初心者向けビデオ チュートリアル

以上がMyBatis のエンティティ Bean のデータベースフィールドと属性間の不一致に対処する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート