亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-11-18 16:28:36 來源:億速云 閱讀:486 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關使用MyBatis時數據庫字段和實體字段不同如何解決,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

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

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

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

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 針對中介標簽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的增刪改查

新增人員信息

首先在PersonMapper.xml中添加insert標簽,我們的數據庫字段user_name,Person實體屬性為name,不一致,區別開來.然后在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 {
  /**
   * 測試數據庫的連接
   * 1.定義一個String類型的變量resource,指向剛才配置的連接數據庫的xml文件
   * 2.創建一個輸入流,來讀取我們的數據庫配置文件
   * 3.輸入流創建工廠.
   * 4.有了工廠之后open工廠
   * 5.通過session訪問配置文件中的sql語句
   */
  SqlSession session = factory.openSession();
  //如何訪問PersonMapper.xml中的sql語句呢&#63; 命名空間+ .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);
  }
 }

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

上述就是小編為大家分享的使用MyBatis時數據庫字段和實體字段不同如何解決了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和平县| 柳州市| 景洪市| 白朗县| 南木林县| 滕州市| 景泰县| 普安县| 磴口县| 犍为县| 阜南县| 彝良县| 黔西| 建湖县| 上犹县| 鹤壁市| 永川市| 荥经县| 澄迈县| 苍溪县| 丹江口市| 无棣县| 砀山县| 静安区| 海宁市| 阿拉善左旗| 绥芬河市| 二连浩特市| 北票市| 甘德县| 沙坪坝区| 宝丰县| 专栏| 临武县| 苏尼特左旗| 灵台县| 项城市| 玛曲县| 清水河县| 治县。| 正安县|