mybatis連接oracle數據庫 SpringData JPA也能寫sql,為什么還要用mybatis?
SpringData JPA也能寫sql,為什么還要用mybatis?在頭條上問這個問題真是太醉了。。順便說一句,胡說八道太多了。國內設計理念為表驅動??傊?,邏輯是由數據表決定的,實現是由模型來完成的
SpringData JPA也能寫sql,為什么還要用mybatis?
在頭條上問這個問題真是太醉了。。順便說一句,胡說八道太多了。
國內設計理念為表驅動??傊?,邏輯是由數據表決定的,實現是由模型來完成的。事實上,這與面向對象的思想截然相反。大多數工程師手中所謂的mybatis的靈活性是,他們不需要考慮如何設計模型。”不管怎樣,我可以用原生SQL來解決這個問題。模型設計太差了,只能靠SQL來修正。JPA是完全對象驅動的思想。早期設計的缺陷會制約后續(xù)的開發(fā),不同的數據庫可以用不同的方式實現(事實上,即使redis也是一樣的)?;卮鹨恍┏R姷膯栴}。
1. JPA表的連接行為具有不確定性和難以控制性。
您確定使用了spring數據JPA嗎?不知道有實體圖嗎?當一個傻瓜達到這個水平時,他能做什么。
2. JPA子查詢不容易實現。
我想你沒用過,是嗎?spring數據JPA的子查詢不僅可以單獨定義視圖,還可以進行子查詢,甚至可以直接使用jpql。
3. JPA不容易優(yōu)化。
我真的不相信99%的優(yōu)化能超過spring data JPA的優(yōu)化。特別是,普通程序員能否停止談論優(yōu)化?他們甚至搞不懂MySQL的鎖。表設計就像一堆廢話,他們仍然每天使用原生SQL。你覺得他們很棒嗎?JPA可以將表屬性反映到對象。當然,運行時優(yōu)化是有基礎的。ORM的發(fā)展空間太大了。任何有點技術知識的人都知道ORM將擁有越來越多的優(yōu)勢。有一點經驗的程序員都知道,在談論其他人之前,是時候先談論良好的維護了。解決性能問題的方法太多了。
最后,難道你不知道ORM cqrs現在是提倡的嗎?請問,有沒有什么復雜的問題沒有原生SQL的介入是無法解決的。
oracle使用mybatis怎么批處理插入?
Mybatis本身僅支持逐個插入。一個愚蠢的方法是遍歷一個列表并在循環(huán)中逐個插入,例如下面的代碼
for(data D:listdata){dataMapper.insertSelective文件(d) }
這是Oracle連接驅動jar的問題。在我使用的驅動程序是ojdbc14jar并更改為classes12.jar之前,我遇到過類似于您的問題。最后,我從Oracle官網下載了ojdbc7.jar,改為jdbc7.jar來解決問題
解決方法:輸入安裝Oracle的路徑
我的驅動程序是g:appOracleproduct12.2.0dbhomeu1networkadminsqlnet.ora文件
英寸sqlnet.ora文件在文件末尾添加以下句子:允許的SQLNET.NET_LOGONuversion=8
只需輸入JDBC 7。Jar在項目的Lib目錄中。我希望它能幫助你