thinkphp里面其實跟原生語句沒有什么區(qū)別,你可以用where限定更新條件,再save($data)中將你要更新的數(shù)據(jù)存在data里面。這樣是你要把數(shù)據(jù)更新成一樣的時候。如果更新的字段及值不一樣的話,據(jù)我所知就只能一條條的循環(huán)更新了。
創(chuàng)新互聯(lián)公司從2013年開始,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元南充做網(wǎng)站,已為上家服務(wù),為南充各地企業(yè)和個人服務(wù),聯(lián)系電話:18980820575
批量的事務(wù)更新數(shù)據(jù)庫時不能更新null時可以這樣進(jìn)行更改操作。lcsql="update"+lc關(guān)聯(lián)子表+"set"+入庫字段+"="+nvl(入庫字段,0)+"+(selectisnull(sum(isnull("+lc工資子表數(shù)據(jù)字段+",0)),0))from"+lc工資子表+"whereRTRIM(LTRIM("+lc工資子表字段+"))='"+c單據(jù)PK+"'"+z原工資子表條件字段+lc條件+"groupby"+lc工資子表依據(jù)字段+")whereRTRIM(LTRIM("+lc關(guān)聯(lián)子表字段+"))='"+lc_jlsjh+"'"+z工資子表條件字段。
第一種就是根據(jù)事務(wù)來實現(xiàn)這個功能,多條更新用事務(wù)來實現(xiàn)和回滾
第二種 就是循環(huán)更新了,這個不需要數(shù)據(jù)一致性,即其中一條語句更新失敗 不影響其他數(shù)據(jù),建議還是用事務(wù)
你先一步步來調(diào)試,先輸出一個$_POST[no]是不是有值?
然后再看看其他post過來的有沒有值?
如果沒有值那肯定是錯的啦。
有啊,只要where后面的條件把握好就行了,把握不好,可能數(shù)據(jù)就苦逼了,
所有:update table1 set num=num+1
條件(num不等于0):update table1 set num=num+1 where num0
更新是要更新兩次 但是你可以用循環(huán)批量更新的!
對數(shù)據(jù)庫的操作是每次一條 或者 你可以寫事務(wù)的,這樣的話就比較麻煩了
就用循環(huán)吧
首先把你的一個tr/tr中的四個內(nèi)容都用相應(yīng)的數(shù)組名字name[]作名字
然后 提交后 得出來數(shù)組長度 然后循環(huán)相應(yīng)的次數(shù)
執(zhí)行SQL操作 就OK
如果具體的 問題 可以 留言