Mybatis入門——基礎方式的增刪該查、mapper動態代理方式的CRUD、類型轉換器

来源:https://www.cnblogs.com/ghlz/archive/2020/01/18/12210092.html

一.基礎方式的增刪該查: 1.mybatis約定:輸入參數parameterType和輸出參數resulrType在形式上只能有一個。 2.如果輸入/輸出參數:是簡單類型(8個基本類型加String)則可以使用任何占位符,#{xxx}; 如果是對象類型,則必須是對象的屬性,#{屬性名}。 3.輸出參 ...


 

一.基礎方式的增刪該查:
1.mybatis約定:輸入參數parameterType和輸出參數resulrType在形式上只能有一個。
2.如果輸入/輸出參數:是簡單類型(8個基本類型加String)則可以使用任何占位符,#{xxx};
                                如果是對象類型,則必須是對象的屬性,#{屬性名}。
3.輸出參數:如果返回值類型是一個對象(如Person),則無論返回一個還是多個,在resultType都寫成org.lanqiao.entity.Person,即resultType="org.lanqiao.entity.Person"。
4.註意事項:a.如果使用的是JDBC事務方式則需要commit手動提,即session.commit();
                    b.所有的標簽<select>.<update>等,都必須有sql語句,但sql參數值可選
                        sql有參數:session.insert(statement,參數值);
 
二.mapper動態代理方式的CRUD(MyBatis介面開發):
原則:約定優於配置
硬編碼方式:abc.java
                                    Configuration conf=new Configuration();
                                    conf.setName("myProject");
配置方式:abc.xml
                                <name>myProject</name>
約定:預設值是myProject
 
具體實現的步驟:
1.基礎環境:mybatis.jar/ojdbc.jar/conf.xml/mapper.xml
2.(不同之處)約定的目標:省略掉statement,即根據約定,直接可以定位到sql語句。
    a.介面,介面中的方法必須遵循以下約定:
          1)方法名和mapper.xml文件中標簽的id值相同;
          2)方法的輸入參數和mapper.xml文件中標簽的parameterType類型一致;
          3)方法的返回值和mapper.xml文件中標簽的resultType類型一致;
除了以上約定,要實現介面中的方法和Mapper.xml中的SQL標簽一一對應,還需要以下一點:
    1)namespace的值,就是介面的全類名(介面-mapper.xml一一對應)
匹配的過程:(約定的過程)
1.根據介面名找到mapper.xml文件
2.根據介面的方法名找到mapper.xml文件中的sql標簽(方法名=sql標簽的id)
習慣:SQL映射文件(mapper.xml)和介面放在同一個包中(註意修改conf.xml文件中載入mapper.xml的路徑)
代碼:PersonMappe personMapper=session.getMapper(PersonMapper.class);
     personMapper.方法
 
優化:
1.可以將配置信息單獨放入db.properties文件中,然後再動態引入
db.properties;
    k=v
<properties resource="db.properties"/>
引入之後使用${key}
2.Mybaites全局參數
    <settings>
            <setting/>
    <settings/>
3.別名:(定義別名時大小寫無所謂)
    a.設置單個別名
    b.設置批量別名
除了自定義別名外,MyBatis還內置了一些常見類的別名。
 
三.類型轉換器:
1.MyBatis自帶的一些常見的類型處理器
    int——number
2.自定義MyBatis類型處理器
    Java——資料庫(jdbc類型)
自定義類型轉換器(boolean-number)步驟:
a.創建轉換器:需要實現TypeHandler介面
        要實現轉換器有兩種選擇:(1)實現介面TypeHandler介面
                                                 (2)繼承BaseTypeHandler
b.配置conf.xml
 
註意:設置Integer時必須是大寫。
 
resultMap可以實現2個功能:
1.類型轉換
2.屬性-欄位的映射關係
 

您的分享是我們最大的動力!

更多相關文章
  • 如果你對自己手速和市面上的各種 “加速包” 都沒什麼信心的話,不妨試試用程式員的手段搶票? 況且,[12306 官方宣佈屏蔽了一大批付費搶票軟體],這也意味著你即使給這些軟體付了會員費,也依舊搶不到票。 所以只能回到最初的手動搶票?No!No!No! GitHub 上有兩個 “年經” 項目,每到春運 ...
  • 一、HashMap(JDK1.8) 1、基本知識、數據結構 (1)時間複雜度:用來衡量演算法的運行時間。 參考:https://blog.csdn.net/qq_41523096/article/details/82142747 (2)數組:採用一段連續的存儲空間來存儲數據。查找方便,增刪麻煩。 (3 ...
  • 基礎知識掃盲 對稱加密 對稱密鑰加密 , 又叫私鑰加密。即信息發送的方和接受方用一個密鑰去加密和揭秘數據。 最大的優勢是 加解密速度快,適合對大量數據進行加密, 對稱加密的缺點是密鑰的管理和分配, 換句話說就是 如何把密鑰發送到需要解密你的消息的人手裡的問題。在發送密鑰的過程中, 密鑰有很大的風險被 ...
  • 深度優先搜索(DFS)和廣度優先搜索(BFS)是基本的暴力技術,常用於解決圖、樹的遍歷問題。 首先考慮演算法思路。以老鼠走迷宮為例: (1):一隻老鼠走迷宮。它在每個路口都選擇先走右邊,直到碰壁無法繼續前進,然後回退一步,這一次走左邊,接著繼續往下走。用這個辦法能走遍所有的路,而且不會重覆。這個思路就 ...
  • [toc] 1、創建虛擬環境 2、安裝Django 3、創建Django工程 4、運行Django項目 5、訪問Django服務 如果出現以下效果表示項目運行成功 到此項目就算創建完成了 ...
  • 究竟是真“自主”,還是又一個披著“洋”皮的“紅芯瀏覽器”? ​ 作者 | 沉迷單車的追風少年 出品 | CSDN博客 昨天看到新聞: ! ​ 心頭一震,看起來很厲害啊!畢竟前幾天美國宣佈要對中國AI軟體進行限制: ​ 這是要還一巴掌的節奏啊。頓時來了興趣,趕緊下載一個嘗嘗鮮。 網上很多類似的新聞,都 ...
  • 新年將至,年味漸濃。 美團點評技術年貨如期而至。 從2013年12月4日發佈第一篇文章,一直到今天,美團技術團隊官方博客已經走過了6個春秋。 由衷地感謝大家一直以來對我們的鼓勵和陪伴! 2020年春節到來之際,我們精選美團技術博客幾十篇技術乾貨以及數篇國際頂會論文,整理製作成一本厚達900多頁的電子 ...
  • 由於下學期要學習JavaEE所以打算將JavaSE的知識再重新學習一遍,打好基礎的同時也希望自己有新的收穫和更深刻的理解。 這次複習主要是參考 "廖雪峰老師的java教程" ,每學習完一章對其中一些要點進行總結和概括。 簡介 Java最早是由SUN公司(已被Oracle收購)的 "詹姆斯·高斯林" ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...