java for循環裏面執行sql語句操做,有效結果只有一次,只執行了一次sql mybatis 循環執行update生效一次 實際只執行一次

java後臺controller中,for循環執行數據庫操做,可是發現實際僅僅執行了一次,或者說提交成功了一次,並無實際的個數循環java

有多是同一個對象致使的sql

 

能夠仔細看一下下面兩段代碼有什麼區別數據庫

ps:代碼無實際意義,只爲演示spa

Entity entity=null;
for(int i=0;i<5;i++){
                        
                         entity= new Entity();
                         entity.setId(i);
                         entity.setCreateTime(new Date());
                        boolean updateResult = Service.update( entity );
                    }

 

Entity entity = new Entity();
for(int i=0;i<5;i++){
                        entity.setId(i);
                        entity.setCreateTime(new Date());
                        boolean updateResult = Service.update(entity );
                    }

 

很明顯上面是聲明瞭一個引用,每一次都建立了一個新的對象,並執行update操做code

下面是同一個對象,不斷地改變賦值,而後執行了update操做對象

其結果大相徑庭:blog

上面的一段代碼,會執行實際的次數,循環0,1,2,3,4    執行5次updateit

下面的代碼僅僅只會執行一次,由於是同一個對象for循環

因此若是循環裏面,調用service,service調用了dao執行了sql,若是發現僅僅只是執行了一次,能夠考慮懷疑是否是對象是同一個class

相關文章
相關標籤/搜索