真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

使用MyBatis時數(shù)據庫字段和實體字段不同如何解決

這期內容當中小編將會給大家?guī)碛嘘P使用MyBatis時數(shù)據庫字段和實體字段不同如何解決,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)是專業(yè)的聊城網站建設公司,聊城接單;提供成都網站制作、成都做網站、外貿營銷網站建設,網頁設計,網站設計,建網站,PHP網站建設等專業(yè)做網站服務;采用PHP框架,可快速的進行聊城網站開發(fā)網頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網站,專業(yè)的做網站團隊,希望更多企業(yè)前來合作!

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

之前數(shù)據庫Person名字字段是name,PersonBean中屬性也是name,但是之后數(shù)據庫中修改為了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標簽,我們的數(shù)據庫字段user_name,Person實體屬性為name,不一致,區(qū)別開來.然后在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 {
  /**
   * 測試數(shù)據庫的連接
   * 1.定義一個String類型的變量resource,指向剛才配置的連接數(shù)據庫的xml文件
   * 2.創(chuàng)建一個輸入流,來讀取我們的數(shù)據庫配置文件
   * 3.輸入流創(chuàng)建工廠.
   * 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("添加人員成功");
  }
 }
}

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

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 //查詢總的記錄條數(shù)
 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);
  }
 }

使用MyBatis時數(shù)據庫字段和實體字段不同如何解決

上述就是小編為大家分享的使用MyBatis時數(shù)據庫字段和實體字段不同如何解決了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


新聞名稱:使用MyBatis時數(shù)據庫字段和實體字段不同如何解決
路徑分享:http://weahome.cn/article/jphjss.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部