一.http協議 二.hibernate緩存模式,級別;Hibernate和mybatis的區別和優缺點 三.SQL優化經驗 四.分散式集群和Redis 五.Spring Aop,動態代理; 六.多線程安全問題,多線程實現 thread local 一.HTTP協議(HyperText Transf ...
一.http協議
二.hibernate緩存模式,級別;Hibernate和mybatis的區別和優缺點
三.SQL優化經驗
四.分散式集群和Redis
五.Spring Aop,動態代理;
六.多線程安全問題,多線程實現 thread local
一.HTTP協議(HyperText Transform protocal 超文本協議)
1.超文本協議是一個基於請求與響應模式的、無狀態的、應用層的協議,常基於TCP的連接方式,http1.1版本是一種連續性連接機制,絕大多數web開發都是構建在http協議之上。
2.網頁響應過程:輸入www.baidu.com回車
功能變數名稱響應-》發起TCP的3次握手-》建立TCP的連接後發起http請求-》伺服器響應http請求,瀏覽器得到HTML代碼-》瀏覽器解析HTML代碼-》頁面渲染
3.http 無狀態的
協議對於事務處理沒有記憶能力
- 主要方法get和post請求方法的區別
1 Get方法主要是向伺服器獲取資源,post重點是向伺服器發送數據;
2.Get傳輸數據通過URL請求,數據可見,用?連接。對用戶可見,明文不安全,Post是通過http的post機制,將欄位對應封存在請求實體中發送給伺服器,對用戶不可見,安全性高;
3.Get方式只支持ASCII字元,中文可能亂碼。Post支持標準字元集,可以傳輸中文。
4.Get傳輸的數據量小,受URL長度的限制,但是效率高。Post可以傳輸大量數據,所以上傳文件時只能用post;
二.Hibernate
- Hibernate緩存機制和三種狀態
緩存就是要將一些經常使用的數據緩存到記憶體或者各種儲存介質中,當再次使用時可以不用去資料庫中查詢,減少與資料庫的交互,提高性能。
再說明一級與二級緩存的作用:一級緩存是Session級別的,也就是說在一個事務中才會啟作用。比如在一個事務中同時查詢同一個對象,則不會兩次去資料庫中查詢。
而二級緩存是sessionFactory級別的,不同的事務之間是可以共用的,有些許可權,當用戶首次登陸後便將關聯的許可權放到二級緩存中,這樣每次需要許可權時就無需再查詢資料庫了。
最後再說明為什麼這樣設計:一般情況下,我們查詢的數據一般是實時的,使用二級緩存肯定不行,使用一級緩存既利用了緩存又不會影響實時。
使用二級緩存是為了存儲一些比較穩定的數據,如許可權,只有在用戶修改了許可權且重新登錄時才能生效。
SessionFactory的緩存分為內置緩存和外置緩存。內置緩存中存放的是SessionFactory對象的一些集合屬性包含的數據(映射元素據及預定SQL語句等),對於應用程式來說,它是只讀的。外置緩存中存放的是資料庫數據的副本,其作用和一級緩存類似.二級緩存除了以記憶體作為存儲介質外,還可以選用硬碟等外部存儲設備。二級緩存稱為進程級緩存或SessionFactory級緩存,它可以被所有session共用,它的生命周期伴隨著SessionFactory的生命周期存在和消亡。
三種狀態:
1. 零時狀態(瞬時狀態Transient) ,new對象開闢記憶體空間 User user=new User();
- 持久狀態(persistent)
該狀態的對象在資料庫中具有對應的記錄,並擁有一個持久化標識.通過session的 get()、load() 等方法獲得的對象都是持久對象。持久化對象被修改變更後,不會馬上同步到資料庫,直到資料庫事務提交。在同步之前,持久化對象是髒的。
- 游離狀態(托管狀態Detached)
當與某持久對象關聯的 session 被關閉後,該持久對象轉變為游離對象.當游離對象被重新關聯到session上 時,又再次轉變成持久對象(在Detached其間的改動將被持久化到資料庫中)。游離對象擁有資料庫的識別值,但已不在持久化管理範圍之內。
2、Hibernate和mybatis區別
Mybatis優勢 面向過程
- MyBatis可以進行更為細緻的SQL優化,可以減少查詢欄位。
- MyBatis容易掌握,而Hibernate門檻較高。
- Hibernate的DAO層開發比MyBatis簡單,Mybatis需要維護SQL和結果映射。
- Hibernate對對象的維護和緩存要比MyBatis好,對增刪改查對象的維護要方便。
- Hibernate資料庫移植性很好,MyBatis的資料庫移植性不好,不同的資料庫需要寫不同SQL。
- Hibernate有更好的二級緩存機制,可以使用第三方緩存。MyBatis本身提供的緩存機制不佳
Hibernate優勢 面向對象
相同點:Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置文件生成SessionFactory,然後由SessionFactory 生成Session,最後由Session來開啟執行事務和SQL語句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。
4.Hibernate工作原理
- 讀取並解析配置文件
- 讀取並解析映射信息,創建session Factory
- 打開session
- 創建事務transation
- 持久化操作
- 提交事務
- 關閉session
- 關閉session factory
5.為什麼要用hibernate
1.對JDBC訪問資料庫的代碼做了封裝,大大簡化了數據訪問層繁瑣的重覆性代碼。
2.Hibernate是一個基於JDBC的主流持久化框架,是一個優秀的ORM實現。他能很大程度的簡化DAO層的編碼工作
3.hibernate使用Java反射機制,而不是位元組碼增強程式來實現透明性。
4.hibernate的性能非常好,因為它是個輕量級框架。映射的靈活性很出色。它支持各種關係資料庫,從一對一到多對多的各種複雜關係。
6.Hibernate是如何延遲載入
涉及延遲載入的有get和load方法,get不會延遲載入,load會延遲載入。另外在many-to-one關係中可以通過lazy屬性設置是否延遲載入。
延遲載入的解釋是動態代理機制,在設置延遲載入後,hibernate返回給我們的對象其實是一個代理對象,並不是真正的對象,該對象沒有真實對象的數據,只有在真正用到對象時(調用get方法時)時,才會觸發hibernate去資料庫查找對象的數據,而且返回的數據不會存儲在代理對象中,是調試視窗查看不到的值。
- Hibernate類之間的關係
配置many-to-one,one-to-many,many-to-many來實現類之間的關係
三.SQL優化經驗
1.用exists代替in,not exists代替not in;in是全表掃描
2.用in代替多個or;用union代替or(適用於索引列)
3.避免在索引列上進行計算,將會全表掃描;在索引列上使用is null和is not null
4.SQL語句大寫,因為Oracle是將其轉化成大寫再執行的
5.union all效率高,但是會有重覆數據;
6. 先用where過濾再group by比用group by再having效率高
資料庫查詢優化
- 對where和order by後的列添加索引;2.儘量避免在where中用null值判斷,這樣索引會失效對全表掃描,可添加預設值再過濾。同理where中用<>或!=,函數操作(索引失效)
四.分散式集群