Heim > Backend-Entwicklung > PHP-Tutorial > 关于laravel事务

关于laravel事务

WBOY
Freigeben: 2016-07-06 13:52:28
Original
885 Leute haben es durchsucht

<code>        DB::beginTransaction();
        foreach($checkArr[0] as $v){
            $id = explode('-',$v)[0];
            $rank = explode('-',$v)[1] != '' ? explode('-',$v)[1] : 5;
            if(index_friendlink::where('id','=',$id)->pluck('online') == 1){
                $updrank = index_friendlink::find($id);
                $updrank -> rank = $rank;
                $updrank -> save();
            }
        }
        $ret = index_friendlink::where('online','=','1')->get();
        foreach($ret as $v) {
            $retRank[] = $v->rank;
        }
        if (count($retRank) != count(array_unique($retRank))) {
            DB::rollback();
            echo '2';
            exit;
        }
        DB::commit();
        
        
        怎么回滚不了,第一次使用laravel,求大神解答,数据库已改成innodb</code>
Nach dem Login kopieren
Nach dem Login kopieren

回复内容:

<code>        DB::beginTransaction();
        foreach($checkArr[0] as $v){
            $id = explode('-',$v)[0];
            $rank = explode('-',$v)[1] != '' ? explode('-',$v)[1] : 5;
            if(index_friendlink::where('id','=',$id)->pluck('online') == 1){
                $updrank = index_friendlink::find($id);
                $updrank -> rank = $rank;
                $updrank -> save();
            }
        }
        $ret = index_friendlink::where('online','=','1')->get();
        foreach($ret as $v) {
            $retRank[] = $v->rank;
        }
        if (count($retRank) != count(array_unique($retRank))) {
            DB::rollback();
            echo '2';
            exit;
        }
        DB::commit();
        
        
        怎么回滚不了,第一次使用laravel,求大神解答,数据库已改成innodb</code>
Nach dem Login kopieren
Nach dem Login kopieren

你的回滚条件是用 PHP 进行判断,而事务应该脱离 PHP ,MySQL 中就能直接实现的吧,比如说删除或者插入失败或者没有走到 commit 回滚。进这个问题看看

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage