mybatis項目源碼
㈠ 基於Spring+SpringMVC+Mybatis分布式敏捷開發系統架構(附源碼)
前言
zheng項目不僅僅是一個開發架構,而是努力打造一套從 前端模板 - 基礎框架 - 分布式架構 - 開源項目 - 持續集成 - 自動化部署 - 系統監測 - 無縫升級 的全方位J2EE企業級開發解決方案。
項目介紹
基於Spring+SpringMVC+Mybatis分布式敏捷開發系統架構,提供整套公共微服務服務模塊:內容管理、支付中心、用戶管理(包括第三方)、微信平台、存儲系統、配置中心、日誌分析、任務和通知等,支持服務治理、監控和追蹤,努力為中小型企業打造全方位J2EE企業級開發解決方案。
技術
名稱
官網
技術
名稱
官網
架構圖
模塊依賴
Spring+SpringMVC+Mybatis框架集成公共模塊,包括公共配置、MybatisGenerator擴展插件、通用BaseService、工具類等。
基於bootstrap實現的響應式Material Design風格的通用後台管理系統,zheng項目所有後台系統都是使用該模塊界面作為前端展示。
各個子系統前台thymeleaf模板,前端資源模塊,使用nginx代理,實現動靜分離。
本系統是基於RBAC授權和基於用戶授權的細粒度許可權控制通用平台,並提供單點登錄、會話管理和日誌管理。接入的系統可自由定義組織、角色、許可權、資源等。用戶許可權=所擁有角色許可權合集+用戶加許可權-用戶減許可權,優先順序:用戶減許可權>用戶加許可權>角色許可權
文件存儲系統,提供四種方案:
阿里雲OSS
服務網關,對外暴露統一規范的介面和包裝響應結果,包括各個子系統的交互介面、對外開放介面、開發加密介面、介面文檔等服務,可在該模塊支持驗簽、鑒權、路由、限流、監控、容錯、日誌等功能。示例圖:
API網關
內容管理系統:支持多標簽、多類目、強大評論的內容管理,有基本單頁展示,菜單管理,系統設置等功能。
統一掃碼支付
通用用戶管理系統, 實現最常用的用戶注冊、登錄、資料管理、個人中心、第三方登錄等基本需求,支持擴展二次開發。
微信公眾號管理平台,除實現官網後台自動回復、菜單管理、素材管理、用戶管理、消息群發等基礎功能外,還有二維碼推廣、營銷活動、微網站、會員卡、優惠券等。
微信小程序後台
基於Netty實現SocketIO的實時推送系統。支持命名空間、二進制數據、SSL、ACK等功能。
環境搭建
開發指南
maven編譯安裝zheng/pom.xml文件即可
啟動演示
約定優於配置(convention over configuration),此框架約定了很多編程規范,下面一一列舉:
資料庫模型
拓撲圖
㈡ Mybatis 婧愮爜璇ュ備綍鍒嗘瀽錛
Mybatis 鏄涓涓浼樼鐨勬寔涔呭眰妗嗘灦錛屽畠鐨勬簮鐮佸垎鏋愬彲浠ヤ粠浠ヤ笅鍑犱釜鏂歸潰鍏ユ墜錛
1. 鏁翠綋鏋舵瀯錛歁ybatis 鐨勬暣浣撴灦鏋勫寘鎷 sqlSession銆丼qlSessionFactory銆丆onfiguration銆丮apper 絳夋ā鍧楋紝鍙浠ラ氳繃闃呰誨畼鏂規枃妗f垨鑰呮簮鐮佹潵浜嗚В榪欎簺妯″潡鐨勪綔鐢ㄥ拰鍏崇郴銆
2. 鍒濆嬪寲榪囩▼錛歁ybatis 鐨勫垵濮嬪寲榪囩▼鍖呮嫭鍔犺澆閰嶇疆鏂囦歡銆佽В鏋愰厤緗淇℃伅銆佸壋寤 SqlSessionFactory 絳夋ラわ紝鍙浠ラ氳繃闃呰 init() 鏂規硶鏉ヤ簡瑙h繖涓榪囩▼銆
3. 緙撳瓨鏈哄埗錛歁ybatis 鎻愪緵浜嗕竴綰х紦瀛樺拰浜岀駭緙撳瓨鏈哄埗錛屽彲浠ラ氳繃闃呰 Cache 綾繪潵浜嗚В榪欎袱涓緙撳瓨鐨勫叿浣撳疄鐜般
4. 鍔ㄦ SQL錛歁ybatis 鏀鎸佸姩鎬 SQL錛屽彲浠ラ氳繃闃呰 DynamicSqlSource 綾繪潵浜嗚В榪欎釜鍔熻兘鐨勫疄鐜般
5. 鍒嗛〉鏌ヨ錛歁ybatis 鏀鎸佸垎欏墊煡璇錛屽彲浠ラ氳繃闃呰 PageHelper 綾繪潵浜嗚В榪欎釜鍔熻兘鐨勫疄鐜般
㈢ MyBatisPlus快速入門源碼筆記共享,拿走吧你
為什麼要學習它呢?
答:MyBatisPlus可以節省我們大量工作時間,所有的CRUD代碼它都可以自動化完成!
優點:
1. 易於上手和掌握。
2. sql寫在xml里,便於統一管理和優化。
3. 解除sql與程序代碼的耦合。
4. 提供映射標簽,支持對象與資料庫的orm欄位關系映射
5. 提供對象關系映射標簽,支持對象關系組建維護
6. 提供xml標簽,支持編寫動態sql。
MyBatis Plus(簡稱 MP)是一個 MyBatis的增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。
就像 魂斗羅 中的 1P、2P,基友搭配,效率翻倍。
特性:
無侵入 :只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑。
損耗小 :啟動即會自動注入基本 CURD,性能基本無損耗,直接面向對象操作 強大的 CRUD 操作 :內置通用 Mapper、通用 Service,僅僅通過少量配置即可實現單表大部分 CRUD 操作,更有強大的條件構造器,滿足各類使用需求 支持 Lambda 形式調用 :通過 Lambda 表達式,方便地編寫各類查詢條件,無需再擔心欄位寫錯。
支持組件自動生成 :支持多達 4 種主鍵策略(內含分布式唯一 ID 生成器 Sequence),可自由配置,完美解決主鍵問題。
支持 ActiveRecord 模式 :支持 ActiveRecord 形式調用,實體類只需繼承 Model 類即可進行強大的 CRUD 操作。
支持自定義全局通用操作 :支持全局通用方法注入( Write once, use anywhere )。
內置代碼生成器 :採用代碼或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 層代碼,支持模板引擎,更有超多自定義配置等您來使用 內置分頁插件 :基於 MyBatis 物理分頁,開發者無需關心具體操作,配置好插件之後,寫分頁等同於普通 List查詢。
分頁插件支持多種資料庫 :支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種資料庫。
內置性能分析插件 :可輸出 Sql 語句以及其執行時間,建議開發測試時啟用該功能,能快速揪出慢查詢。
內置全局攔截插件 :提供全表 delete 、 update 操作智能分析阻斷,也可自定義攔截規則,預防誤操作。
1.1 、引入mybatis-plus相關maven依賴
引入mybatis-plus在spring boot中的場景啟動器
ps:切記不可再在pom.xml文件中引入mybatis與mybatis-spring的maven依賴,這一點,mybatis-plus的官方文檔中已經說明的很清楚了.
1.2、創建數據表
(1)SQL語句
(2) 數據表結構
1.3、 創建java bean
根據數據表新建相關實體類
1 package com.example.demo.pojo
1.4、 配置application.proprties
數據源使用druid
ps:在進行crud實驗之前,簡單對mybatis與mybatis-plus做一個簡單的對比
2.1、mybatis與mybatis-plus實現方式對比
(1)提出問題: 假設我們已存在一張 tbl_employee 表,且已有對應的實體類 Employee,實現 tbl_employee 表的 CRUD操作我們需要做什麼呢?
(2)實現方式: 基於 Mybatis 需要編寫 EmployeeMapper 介面,並手動編寫 CRUD 方法 提供 EmployeeMapper.xml 映射文件,並手動編寫每個方法對應的 SQL 語句. 基於 Mybatis-plus 只需要創建 EmployeeMapper 介面, 並繼承BaseMapper 介面.這就是使用 mybatis-plus 需要完成的所有操作,甚至不需要創建 SQL 映射文件。
2.2、BaseMapper介面介紹
(1)如何理解核心介面BaseMapper?
在使用Mybatis-Plus時,核心操作類是BaseMapper介面,其最終也是利用的Mybatis介面編程的實現機制,其默認提供了一系列的增刪改查的基礎方法,並且開發人員對於這些基礎操作不需要寫SQL進行處理操作(Mybatis提供的機制就是需要開發人員在mapper.xml中提供sql語句),那樣我們可以猜測肯定是Mybatis-Plus完成了BaseMapper介面提供的方法的SQL語句的生成操作。
(2)BaseMapper介面為我們定義了哪些方法?
BaseMapper介面源碼:
(3) mybatis-plus中常用的註解 1
由於我們的數據表名於實體類的類名不一致,並且實體類於數據表還存在欄位名不對應的情況,因此我們需要引入mybatis-plus的註解.
編寫EmployeeMapper介面繼承BaseMapper介面
准備考試環境:
(1)插入
(2)修改
控制台列印出的sql語句
如果我們不設置實體類的email與gender屬性,結果是怎樣的呢?
控制台sql語句:
顯然,mybatis-plus為我們做了非空判斷,空值的話,默認不更新對應的欄位.想一想,這是不是類似於mybatis中的動態sql呢?
這種處理效果又會帶來什麼好處呢?
(3)查詢
selectById方法
selectBatchIds方法
ps:發現該方法底層使用的竟然是sql的in關鍵字
selectByMap方法
(4)刪除
3、不得不提的條件構造器---Wrapper
3.1.wrapper及其子類介紹
(1)Wrapper :條件構造抽象類,最頂端父類,抽象類中提供3個方法以及其他方法.
㈣ 如何在mybatis中調試查看生成的sql語句
mybatis的源碼中查看生成的sql語句,參考執行以下代碼即可。具體代碼如下:
把裡面PooledDataSource類的log輸出部分,換成log.warn之後,重新打jar包,放到項目中,日誌級別改為info,如:
log4j.rootLogger=info,stdout,R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[service]%d-%c-%-4r[%t]%-5p%c%x-%m%n
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.File=../logs/service.log
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=[service]%d-%c-%-4r[%t]%-5p%c%x-%m%n
log4j.logger.com.ibatis=debug
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=debug
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=debug
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=debug
log4j.logger.java.sql.Connection=debug
log4j.logger.java.sql.Statement=debug
log4j.logger.java.sql.PreparedStatement=debug
log4j.logger.java.sql.ResultSet=debug