首頁> Java> java教程> 主體

MyBatis出現資料庫欄位和實體bean中屬性不一致時處理方法

Y2J
發布: 2018-05-18 17:10:18
原創
7057 人瀏覽過

這篇文章主要介紹了MyBatis入門之增刪改查+資料庫欄位和實體欄位不一致問題處理方法,需要的朋友可以參考下

當資料庫欄位和實體bean中屬性不一致時

之前資料庫Person名字欄位是name,PersonBean中屬性也是name,但是之後資料庫中修改為了user_name,

方法1:透過sql語句的欄位起別名,別名和實體中的物件屬性一致

SELECT id,user_name as name,sex,age from person 
登入後複製

方法2: mybatis最強大的地方: reslutMap物件

#新增一個中介reslutMap標籤,並將select標籤中的resultType改為resultMap,並對應resultMap標籤的id.

結果集:resultType 基礎類型,int,string,Person,

resultMap針對中介標籤resultMap而存在.

              
登入後複製

mybatis的增刪改查

新增人員資訊

首先在PersonMapper .xml中加入insert標籤,我們的資料庫欄位user_name,Person實體屬性為name,不一致,區別開來.然後在TestMybatis中寫入程式碼.

  INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex}) 
登入後複製

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 { /** * 测试数据库的连接 * 1.定义一个String类型的变量resource,指向刚才配置的连接数据库的xml文件 * 2.创建一个输入流,来读取我们的数据库配置文件 * 3.输入流创建工厂. * 4.有了工厂之后open工厂 * 5.通过session访问配置文件中的sql语句 */ SqlSession session = factory.openSession(); //如何访问PersonMapper.xml中的sql语句呢? 命名空间+ .id List 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 person SET user_name=#{name},age=#{age} WHERE id=#{id}   
登入後複製

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); }
登入後複製

條件查詢

根據條件查詢

  @Test //带条 件查询 public void selByL(){ SqlSession session = factory.openSession(); Map map = new HashMap(); map.put("name","luo%"); map.put("sex",1); List 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免費影片教學

3.JAVA初級入門影片教學

以上是MyBatis出現資料庫欄位和實體bean中屬性不一致時處理方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!