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

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

一.基礎方式的增刪該查: 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.屬性-欄位的映射關係  
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果你對自己手速和市面上的各種 “加速包” 都沒什麼信心的話,不妨試試用程式員的手段搶票? 況且,[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收購)的 "詹姆斯·高斯林" ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...