国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

10分鐘手擼極簡版ORM框架!

開發 架構
ORM框架到底是如何運行的?ORM框架是如何將程序對象與數據庫中的數據進行映射的?不過,在正式開始手擼ORM框架之前,我們要先來搞清楚什么是ORM框架。

[[402491]]

大家好,我是冰河~~

最近很多小伙伴對ORM框架的實現很感興趣,不少讀者在冰河的微信上問:冰河,你知道ORM框架是如何實現的嗎?比如像MyBatis和Hibernte這種ORM框架,它們是如何實現的呢?

為了能夠讓小伙伴們更加深刻并且清晰的理解ORM框架的實現原理,冰河決定自己手擼一個極簡版的ORM框架,讓小伙伴們一看就能夠明白什么是ORM框架?ORM框架到底是如何運行的?ORM框架是如何將程序對象與數據庫中的數據進行映射的?不過,在正式開始手擼ORM框架之前,我們要先來搞清楚什么是ORM框架。

什么是ORM框架?

ORM全稱為:Object Relational Mapping,翻譯成中文就是:對象關系映射。也就是說ORM框架就是對象關系映射框架,它通過元數據描述對象與關系映射的細節,ORM框架在運行的時候,可以根據對應與映射之間的關系將數據持久化到數據庫中。

其實,從本質上講,ORM框架主要實現的是程序對象到關系數據庫數據的映射。說的直白點:ORM框架就是將實體和實體與實體之間的關系,轉化為對應的SQL語句,通過SQL語句操作數據庫,將數據持久化到數據庫中,并且對數據進行相應的增刪改查操作。

最常用的幾種ORM框架為:MyBatis、Hibernate和JFinal。

手擼ORM框架

這里,我們模擬的是手擼Hibernate框架實現ORM,小伙伴們也可以模擬其他的ORM框架實現,核心原理都是相通的。如果大家在模擬其他框架手擼實現ORM時,遇到問題的話,都可以私聊我溝通,我看到的話,會第一時間回復大家。

好了,說干就干,我們開始吧。

@Table注解的實現

首先,我們創建一個io.mykit.annotation.jdk.db.provider Java包,在這個Java包創建一個@Table注解,@Table注解標注在Java類上,表示當前類會被映射到數據庫中的哪張數據表上,如下所示。

  1. package io.mykit.annotation.jdk.db.provider; 
  2. import java.lang.annotation.Documented; 
  3. import java.lang.annotation.ElementType; 
  4. import java.lang.annotation.Inherited; 
  5. import java.lang.annotation.Retention; 
  6. import java.lang.annotation.RetentionPolicy; 
  7. import java.lang.annotation.Target; 
  8. /** 
  9.  * 自定義Table注解 
  10.  * @author binghe 
  11.  * 
  12.  */ 
  13. @Inherited 
  14. @Target({ElementType.TYPE}) 
  15. @Retention(RetentionPolicy.RUNTIME) 
  16. @Documented 
  17. public @interface Table { 
  18.  String value() default ""

@Column注解的實現

同樣的,在io.mykit.annotation.jdk.db.provider包下創建一個@Column注解,@Column注解標注在類中的字段上,表示當前類中的字段映射到數據表中的哪個字段上,如下所示。

  1. package io.mykit.annotation.jdk.db.provider; 
  2.   
  3. import java.lang.annotation.Documented; 
  4. import java.lang.annotation.ElementType; 
  5. import java.lang.annotation.Inherited; 
  6. import java.lang.annotation.Retention; 
  7. import java.lang.annotation.RetentionPolicy; 
  8. import java.lang.annotation.Target; 
  9.   
  10. /** 
  11.  * 自定義Column注解 
  12.  * @author binghe 
  13.  * 
  14.  */ 
  15. @Inherited 
  16. @Target({ElementType.FIELD}) 
  17. @Retention(RetentionPolicy.RUNTIME) 
  18. @Documented 
  19. public @interface Column { 
  20.  String value() default ""

看到這里,不管是使用過MyBatis的小伙伴還是使用過Hibernate的小伙伴,應該都會有所體會吧?沒錯,@Table注解和@Column注解,不管是在MyBatis框架還是Hibernate框架中,都會被使用到。這里,我們在收錄極簡版ORM框架時,也使用了這兩個經典的注解。

創建實體類

在io.mykit.annotation.jdk.db.provider.entity包下創建實體類User,并且@Table注解和@Column注解會被分別標注在User類上和User類中的字段上,將其映射到數據庫中的數據表和數據表中的字段上,如下所示。

  1. package io.mykit.annotation.jdk.db.provider.entity; 
  2.   
  3. import io.mykit.annotation.jdk.db.provider.Column
  4. import io.mykit.annotation.jdk.db.provider.Table
  5.   
  6. /** 
  7.  * 自定義使用注解的實體 
  8.  * @author binghe 
  9.  * 
  10.  */ 
  11. @Table("t_user"
  12. public class User implements Serializable
  13.   
  14.  @Column("id"
  15.  private String id; 
  16.   
  17.  @Column("name"
  18.  private String name
  19.   
  20.  public User() { 
  21.   super(); 
  22.  } 
  23.   
  24.  public User(String id, String name) { 
  25.   super(); 
  26.   this.id = id; 
  27.   this.name = name
  28.  } 
  29.   
  30.  public String getId() { 
  31.   return id; 
  32.  } 
  33.   
  34.  public void setId(String id) { 
  35.   this.id = id; 
  36.  } 
  37.   
  38.  public String getName() { 
  39.   return name
  40.  } 
  41.   
  42.  public void setName(String name) { 
  43.   this.name = name
  44.  } 
  45.   
  46.  @Override 
  47.  public String toString() { 
  48.   return "User [id=" + id + ", name=" + name + "]"
  49.  } 
  50.   

注解解析類的實現

在io.mykit.annotation.jdk.db.provider.parser包中創建一個AnnotationParser類,AnnotationParser 類是整個框架的核心,它負責解析標注在實體類上的注解,并且將對應的實體類及其字段信息映射到對應的數據表和字段上,如下所示。

  1. package io.mykit.annotation.jdk.db.provider.parser; 
  2.   
  3. import java.lang.reflect.Field; 
  4. import java.lang.reflect.Method; 
  5.   
  6. import io.mykit.annotation.jdk.db.provider.Column
  7. import io.mykit.annotation.jdk.db.provider.Table
  8.   
  9. /** 
  10.  * 解析自定義注解 
  11.  * @author binghe 
  12.  * 
  13.  */ 
  14. public class AnnotationParser { 
  15.  /**  
  16.      * 通過注解來組裝查詢條件,生成查詢語句  
  17.      * @param obj  
  18.      * @return  
  19.      */   
  20.     public static String assembleSqlFromObj(Object obj) {   
  21.         Table table = obj.getClass().getAnnotation(Table.class);   
  22.         StringBuffer sbSql = new StringBuffer();   
  23.         String tableName = table.value();   
  24.         sbSql.append("select * from " + tableName + " where 1=1 ");   
  25.         Field[] fileds = obj.getClass().getDeclaredFields();   
  26.         for (Field f : fileds) {   
  27.             String fieldName = f.getName();   
  28.             String methodName = "get" + fieldName.substring(0, 1).toUpperCase()   
  29.                     + fieldName.substring(1);   
  30.             try {   
  31.                 Column column = f.getAnnotation(Column.class);   
  32.                 if (column != null) {   
  33.                     Method method = obj.getClass().getMethod(methodName);   
  34.                     Object v = method.invoke(obj);   
  35.                     if (v != null) {   
  36.                         if (v instanceof String) {   
  37.                          String value = v.toString().trim(); 
  38.                             // 判斷參數是不是 in 類型參數 1,2,3   
  39.                             if (value.contains(",")) {   
  40.                              //去掉value中的, 
  41.                              String sqlParams = value.replace(",""").trim(); 
  42.                              //value中都是純數字 
  43.                              if(isNum(sqlParams)){ 
  44.                               sbSql.append(" and " + column.value() + " in (" + value + ") ");   
  45.                              }else
  46.                               String[] split = value.split(","); 
  47.                               //將value重置為空 
  48.                               value = ""
  49.                               for(int i = 0; i < split.length - 1; i++){ 
  50.                                value += "'"+split[i]+"',"
  51.                               } 
  52.                               value += "'"+split[split.length - 1]+"'"
  53.                               sbSql.append(" and " + column.value() + " in (" + value + ") ");   
  54.                              } 
  55.                             } else {   
  56.                              if(value != null && value.length() > 0){ 
  57.                               sbSql.append(" and " + column.value() + " like '%" + value + "%' ");   
  58.                              } 
  59.                             }   
  60.                         } else { 
  61.                             sbSql.append(" and " + column.value() + "=" + v.toString() + " ");   
  62.                         }   
  63.                     }   
  64.                 }   
  65.             } catch (Exception e) {   
  66.                 e.printStackTrace();   
  67.             }   
  68.         }   
  69.         return sbSql.toString();   
  70.     }   
  71.    
  72.     /**  
  73.      * 檢查給定的值是不是 id 類型 1.檢查字段名稱 2.檢查字段值  
  74.      *   
  75.      * @param target  
  76.      * @return  
  77.      */   
  78.     public static boolean isNum(String target) {   
  79.         boolean isNum = false;   
  80.         if (target.toLowerCase().contains("id")) {   
  81.             isNum = true;   
  82.         }   
  83.         if (target.matches("\\d+")) {   
  84.             isNum = true;   
  85.         }   
  86.         return isNum;   
  87.     }   

至此,我們的極簡版ORM框架就實現好了,不過實現完還不行,我們還要對其進行測試驗證。

測試類的實現

在io.mykit.annotation.jdk.provider包下創建AnnotationTest 類,用以測試我們實現的極簡ORM框架的效果,具體如下所示。

  1. package io.mykit.annotation.jdk.provider; 
  2.   
  3. import org.junit.Test; 
  4.   
  5. import io.mykit.annotation.jdk.db.provider.entity.User
  6. import io.mykit.annotation.jdk.db.provider.parser.AnnotationParser; 
  7. import io.mykit.annotation.jdk.provider.parser.AnnotationProcessor; 
  8.   
  9. /** 
  10.  * 測試自定義注解 
  11.  * @author binghe 
  12.  * 
  13.  */ 
  14. public class AnnotationTest { 
  15.   
  16.  @Test 
  17.  public void testDBAnnotation(){ 
  18.   User testDto = new User("123""34");   
  19.   User testDto1 = new User("123""test1");   
  20.   User testDto2 = new User("""test1,test2,test3,test4");   
  21.         String sql = AnnotationParser.assembleSqlFromObj(testDto);   
  22.         String sql1 = AnnotationParser.assembleSqlFromObj(testDto1);   
  23.         String sql2 = AnnotationParser.assembleSqlFromObj(testDto2);   
  24.         System.out.println(sql);   
  25.         System.out.println(sql1);   
  26.         System.out.println(sql2);   
  27.  } 

運行測試

我們運行AnnotationTest#testDBAnnotation()方法,命令行會輸出如下信息。

  1. select * from t_user where 1=1  and id like '%123%'  and name like '%34%'  
  2. select * from t_user where 1=1  and id like '%123%'  and name like '%test1%'  
  3. select * from t_user where 1=1  and name in ('test1','test2','test3','test4')  

可以看到,我們在測試程序中,并沒有在測試類中傳入或者執行任何SQL語句,而是直接創建User類的對象,并調用AnnotationParser#assembleSqlFromObj()進行解析,并且將對應的實體類對象轉換為SQL語句返回。

本文轉載自微信公眾號「冰河技術」,可以通過以下二維碼關注。轉載本文請聯系冰河技術公眾號。

 

責任編輯:武曉燕 來源: 冰河技術
相關推薦

2021-10-12 09:24:02

Java線程池源碼

2020-08-17 10:50:29

Python代碼get

2019-08-15 07:13:54

負載平衡服務器遷移IIS

2020-02-17 13:45:27

抓取代碼工具

2014-03-25 09:50:00

解釋器編程語言

2021-07-15 06:43:11

Bash調試腳本

2013-09-13 14:08:01

2021-04-23 09:50:41

topLinux命令

2020-10-13 18:22:58

DevOps工具開發

2014-08-08 09:30:04

android scrollview

2024-06-11 00:00:00

Java線程安全緩存組件

2018-11-28 11:20:53

Python函數式編程編程語言

2021-08-01 21:38:07

網頁點燈網關

2022-08-29 15:02:53

遠程桌面

2020-10-29 08:28:42

Java NIO異步非阻塞

2020-12-07 11:23:32

Scrapy爬蟲Python

2021-05-17 20:13:50

數倉操作型數據庫

2021-05-28 07:38:20

內存溢出場景

2023-06-03 21:14:47

Linux

2019-07-18 16:32:06

Python函數數據
點贊
收藏

51CTO技術棧公眾號

男女超爽视频免费播放| 污视频网站免费看| 国产亚洲一区| 亚洲无线码在线一区观看| 久久大片网站| 一区二区三区四区精品视频| 日精品一区二区| 欧美日韩在线视频一区| 一二三四区精品视频| 欧美日韩中文字幕| 国产69精品久久久久毛片| 欧美综合在线视频| 国产精品色噜噜| 精品女厕一区二区三区| 人妻丰满熟妇av无码区app| 美女精品一区| 狠狠色综合网站久久久久久久| 成人3d精品动漫精品一二三| 97久久久免费福利网址| 国产图片一区| 日韩性xxxx爱| 欧美日韩国产一区二区在线观看| 久久精品国产一区二区电影| 999精品嫩草久久久久久99| 视频一区视频二区国产精品 | 国产日韩免费| 噜噜噜噜噜久久久久久91| 一本色道久久综合亚洲精品高清| 国产伦精品一区二区三区照片91| 日韩亚洲国产欧美| 亚洲国产一区二区三区在线播| 欧美在线日韩精品| 精品成人av| 无吗不卡中文字幕| 国产在线一区二区三区四区 | 欧美日韩亚洲一区二区三区在线观看 | 久久国产婷婷国产香蕉| 26uuu欧美日本| 最近2019中文字幕一页二页| 亚洲欧美激情网| 主播大秀视频在线观看一区二区| 26uuu欧美日本| 日韩国产欧美一区| 极品少妇一区二区三区| 欧美成人精品影院| 成年人视频在线看| 国产福利一区二区三区在线视频| 亚洲黄色一区二区三区| 99久久99视频只有精品| 精品国产一区二区三区久久| 亚洲超碰在线观看| 国产区一区二区| av一区二区久久| avtt天堂资源网| 亚洲国产精品高清| 500福利第一精品导航| 亚洲精品国产a| 在线观看国产视频| 中文字幕一区二区在线观看| 精品久久久久久久无码| 国产精品午夜在线观看| 精品剧情v国产在线观看| 亚洲国产一区视频| 撸视在线观看免费视频| 日韩欧美国产电影| 日本在线成人| 国产区精品在线观看| 青青草一区二区三区| 屁屁影院在线观看| 欧美日韩免费观看一区二区三区| 欧美另类视频在线| 亚洲理论电影网| 国产精品pans私拍| 超碰超碰人人人人精品| 日韩国产中文字幕| 999精品一区| av免费在线观| 国产一区二区视频免费在线观看| 国产精品毛片久久久久久久| 秋霞a级毛片在线看| 欧美超级免费视 在线| 国产精品欧美一区喷水| 成人h视频在线观看| 在线高清欧美| 国产精品高清网站| 国产一区二区在线影院| 麻豆传媒在线播放| 国产成人精品123区免费视频| 久久免费国产视频| 精品极品在线| 久久久久国产精品麻豆| 国产高清免费av在线| 成人97在线观看视频| 亚洲综合国产激情另类一区| 成人黄色网页| 日韩视频在线一区| 日韩中文字幕亚洲一区二区va在线 | 91好吊色国产欧美日韩在线| 日韩欧美精品网址| 韩国一区二区三区视频| 日韩精品福利视频| 疯狂做受xxxx欧美肥白少妇| 日韩色性视频| 视频一区国产精品| 91成人在线精品| 亚洲高清极品| 日韩 欧美 高清| 亚洲人成网在线播放| 噜噜噜91成人网| 免费在线稳定资源站| 538国产精品视频一区二区| 国产91对白在线观看九色| 毛片在线导航| 久久久久免费网| 欧美午夜片在线免费观看| 欧美**字幕| 亚洲欧美国产中文| 日韩在线中文视频| 成人免费三级在线| 欧美影视资讯| 成年人深夜视频| 亚洲免费高清视频| 韩国视频一区二区| cao在线视频| 亚洲成人蜜桃| 欧美成人高清电影在线| 午夜一级久久| 麻豆影视在线观看_| 精品免费一区二区三区蜜桃| 欧美色图片你懂的| 亚洲国产精品一区制服丝袜| 无遮挡的视频在线观看| 国产亚洲自拍偷拍| 日韩一级片在线观看| 美女网站色91| 日本综合视频| 国产情侣av自拍| 欧美一区二区三区免费视| 亚洲欧美日韩人成在线播放| 少妇精品久久久一区二区| 黄色资源在线看| 国产日韩欧美另类| 欧美在线观看视频在线| 先锋影音国产一区| а√天堂中文资源在线bt| 伊人再见免费在线观看高清版| 国产一区二区三区中文| 久久色在线观看| 奇米影视777在线欧美电影观看 | 亚洲第一在线视频| 欧美午夜寂寞| 亚洲中文字幕久久精品无码喷水| 神马久久桃色视频| 国产午夜精品久久久久久免费视| 波多野结衣欧美| 免费视频二区| 99伊人久久| 亚洲国产天堂久久综合| av网站免费线看精品| 曰本一区二区三区视频| 国产尤物视频在线| 亚洲最大免费| 日韩高清欧美激情| 天堂av在线电影| 黄色大片中文字幕| 青青久久aⅴ北条麻妃| 91成人国产精品| 久久se这里有精品| 99国产精品免费网站| 最近最好的中文字幕2019免费| 国产一级精品aaaaa看| 精品亚洲一区二区三区| 国产片一区二区| 欧美在线视屏| 国产精品亚洲d| www.男人的天堂.com| 欧美日韩国产高清视频| 精品国产美女在线| 色综合久久天天| 福利电影一区二区| 亚洲91中文字幕无线码三区| 国产在线天堂www网在线观看| 爱情岛论坛亚洲首页入口章节| 亚洲自拍偷拍色片视频| 亚洲性生活视频在线观看| 亚洲一区二区成人在线观看| 免费久久精品视频| 亚洲国产国产| 牛牛在线精品视频| h片免费观看| 中文字幕一区二区中文字幕| 日本精品一区二区三区在线播放视频| 日韩免费一区二区三区在线播放| 亚洲欧洲av在线| 国产一区二区三区视频在线播放| 精品国产一区二区三区小蝌蚪| 69av成人| 四虎精品成人免费网站| 亚洲美免无码中文字幕在线| 国产伦精品一区二区三区在线|