欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis入門之增刪改查+數(shù)據(jù)庫字段和實(shí)體字段不一致問題處理方法

 更新時(shí)間:2017年05月06日 10:50:38   作者:洛GG  
這篇文章主要介紹了MyBatis入門之增刪改查+數(shù)據(jù)庫字段和實(shí)體字段不一致問題處理方法,需要的朋友可以參考下

當(dāng)數(shù)據(jù)庫字段和實(shí)體bean中屬性不一致時(shí)

之前數(shù)據(jù)庫Person名字字段是name,PersonBean中屬性也是name,但是之后數(shù)據(jù)庫中修改為了user_name,

方法1:通過sql語句的字段起別名,別名和實(shí)體中的對象屬性一致

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最強(qiáng)大的地方 : reslutMap對象

添加一個(gè)中介reslutMap標(biāo)簽,并將select標(biāo)簽中的resultType改為resultMap,并對應(yīng)resultMap標(biāo)簽的id.

結(jié)果集:resultType 基礎(chǔ)類型,int,string,Person,

resultMap 針對中介標(biāo)簽resultMap而存在.

<!--配置命名空間,命名空間+ .id 是唯一的sql語句標(biāo)示符-->
<mapper namespace="com.luogg.mapper.PersonMapper">
 <!--中介,當(dāng)數(shù)據(jù)庫字段和實(shí)體bean對象屬性不一致時(shí),做一個(gè)對應(yīng)關(guān)系-->
 <resultMap id="personRM" type="com.luogg.domain.Person">
  <!--主鍵映射-->
  <id property="id" column="ID"></id>
  <!--普通字段,property指實(shí)體屬性,column結(jié)果集的字段名稱,一致的字段可以不寫-->
  <result property="name" column="USER_NAME"></result>
 </resultMap>
 <!--查詢所有數(shù)據(jù),參數(shù)有id,resultType結(jié)果集,parameterType參數(shù)-->
 <!--注意 : sql語句中如果有要填寫集合的,比如查詢所有數(shù)據(jù),返回一個(gè)Person的結(jié)果集,那么resultType參數(shù)直接寫 路徑+集合的類型
  比如: 返回一個(gè)Person集合,那么就填寫Person Bean所在的路徑+Person-->
 <select id="find" resultMap="personRM">
  SELECT * from person
 </select>
 <!--通過ID查詢數(shù)據(jù),當(dāng)有查詢條件時(shí),需要寫parameterType,返回結(jié)果集仍然是Person, #{id}或者${id}都可以-->
 <select id="selById" parameterType="int" resultType="com.luogg.domain.Person">
  SELECT * FROM person WHERE id = #{id}
 </select>
</mapper>

    mybatis的增刪改查

新增人員信息

首先在PersonMapper.xml中添加insert標(biāo)簽,我們的數(shù)據(jù)庫字段user_name,Person實(shí)體屬性為name,不一致,區(qū)別開來.然后在TestMybatis中寫入代碼.

<!--添加人員-->
 <insert id="insert" parameterType="com.luogg.domain.Person">
  INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex})
 </insert>

package test;

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 {
  /**
   * 測試數(shù)據(jù)庫的連接
   * 1.定義一個(gè)String類型的變量resource,指向剛才配置的連接數(shù)據(jù)庫的xml文件
   * 2.創(chuàng)建一個(gè)輸入流,來讀取我們的數(shù)據(jù)庫配置文件
   * 3.輸入流創(chuàng)建工廠.
   * 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查詢?nèi)藛T信息
 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("添加人員成功");
  }
 }
}

修改人員信息 , 查詢總的記錄條數(shù)

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 //查詢總的記錄條數(shù)
 public void selCount(){
  SqlSession session = factory.openSession();
  int i = session.selectOne("com.luogg.mapper.PersonMapper.count");
  System.out.println(i);
 }

條件查詢

根據(jù)條件查詢

<!--帶條件查詢-->
 <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);
  }
 }

以上所述是小編給大家介紹的MyBatis入門之增刪改查+數(shù)據(jù)庫字段和實(shí)體字段不一致問題處理方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時(shí)回復(fù)大家的!

相關(guān)文章

  • 淺談在springboot中使用定時(shí)任務(wù)的方式

    淺談在springboot中使用定時(shí)任務(wù)的方式

    今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識,文章圍繞著在springboot中使用定時(shí)任務(wù)的方式展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • Java反射及性能詳細(xì)

    Java反射及性能詳細(xì)

    這篇文章主要介紹了Java反射及性能,現(xiàn)如今的java工程中,反射的使用無處無在。無論是設(shè)計(jì)模式中的代理模式,還是紅透半邊天的Spring框架中的IOC,AOP等等,都存在大量反射的影子。下面我們就對該話題進(jìn)行詳細(xì)介紹,感興趣的小伙伴可以參考一下
    2021-10-10
  • java中List對象列表實(shí)現(xiàn)去重或取出及排序的方法

    java中List對象列表實(shí)現(xiàn)去重或取出及排序的方法

    這篇文章主要介紹了關(guān)于java中List對象列表實(shí)現(xiàn)去重或取出以及排序的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • @ComponentScan注解用法之包路徑占位符解析

    @ComponentScan注解用法之包路徑占位符解析

    這篇文章主要介紹了@ComponentScan注解用法之包路徑占位符解析,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java中的Semaphore源碼分析

    Java中的Semaphore源碼分析

    這篇文章主要介紹了Java中的Semaphore源碼分析,Semaphore是一個(gè)訪問公共資源的線程數(shù)量如限流、停車等,它是一個(gè)基于AQS實(shí)現(xiàn)的共享鎖,主要是通過控制state變量來實(shí)現(xiàn),需要的朋友可以參考下
    2023-11-11
  • maven項(xiàng)目無法讀取到resource文件夾的問題

    maven項(xiàng)目無法讀取到resource文件夾的問題

    這篇文章主要介紹了maven項(xiàng)目無法讀取到resource文件夾的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • java.lang.IllegalArgumentException:Invalid character found異常解決

    java.lang.IllegalArgumentException:Invalid character&nb

    本文介紹了java.lang.IllegalArgumentException: Invalid character found異常的解決,方法包括檢查代碼中的方法名,使用合適的HTTP請求方法常量,使用第三方HTTP庫,檢查請求URL以及使用調(diào)試和日志工具,通過這些方法,我們可以解決異常并確保網(wǎng)絡(luò)應(yīng)用程序的正常運(yùn)行
    2023-10-10
  • Java高版本Api在Android中的使用方法詳解

    Java高版本Api在Android中的使用方法詳解

    API(Application?Programming?Interface)應(yīng)用程序編程接口,java?API是一本程序員字典,是JDK提供給我們使用的類的說明文檔,下面這篇文章主要給大家介紹了關(guān)于Java高版本Api在Android中的使用方法,需要的朋友可以參考下
    2022-05-05
  • java LeetCode題解KMP算法示例

    java LeetCode題解KMP算法示例

    這篇文章主要為大家介紹了java LeetCode題解KMP算法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 詳解IDEA 中使用Maven創(chuàng)建項(xiàng)目常見錯誤和使用技巧(推薦)

    詳解IDEA 中使用Maven創(chuàng)建項(xiàng)目常見錯誤和使用技巧(推薦)

    這篇文章主要介紹了詳解IDEA 中使用Maven創(chuàng)建項(xiàng)目常見錯誤和使用技巧(推薦),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07

最新評論