laravel db与model常用方法

一、laravel中DB类的使用
1.使用DB门面的table方法,table方法为给定表返回一个查询构建器,允许你在查询上链接更多约束条件并最终返回查询结果。我们使用get方法获取表中所有记录,和原生查询一样,get方法返回结果集的数据组,其中每一个结果都是PHP对象的StdClass实例。你可以像访问对象的属性一样访问列的值。

namespace App\Http\Controllers;
    use DB;
    use App\Http\Controllers\Controller;
    class UserController extends Controller{
        /**
         * 显示用户列表
         *
         * @return Response
         */
        public function index()
        {
            $users = DB::table('users')->get();
            return view('user.index', ['users' => $users]);
        }
    }

2.从一张表中获取一行或一列,如果我们只是想要从数据表中获取一行数据,可以使用first方法,该方法将会返回单个StdClass对象.

$user = DB::table('users')->where('name', 'John')->first();
echo $user->name;

3.从一张表中获取组块结果集,如果我们需要处理成千上百条数据库记录,可以考虑使用chunk方法,该方法一次获取结果集的一小块,然后填充每一小块数据到要处理的闭包,该方法在编写处理大量数据库记录的Artisan命令的时候非常有用。比如,我们在批量处理删除或更新的时候使用方法非常有用:

DB::table('users')->chunk(100, function($users) {
    foreach ($users as $user) {
          $user->delete();
    }
});

还可以通过从闭包函数中返回false来中止组块的运行:

DB::table('users')->chunk(100, function($users) {
    return false;
});

如果想要获取包含单个列值的数组,可以使用lists方法,在本例中,我们获取所有title的数组:

$titles = DB::table('users')->lists('title');
foreach ($titles as $title) {
    echo $title;
}

在还可以在返回数组中为列值指定更多的自定义键(该自定义键必须是该表的其它字段列名,否则会报错:

$users = DB::table('users')->lists('title', 'name');
    foreach ($users as $name => $title) {
        echo $title;
    }
}

二、内连接
查询构建器还可以用于编写基本的SQL“内连接”,你可以使用查询构建器实例上的join方法,传递给join方法的第一次参数是你需要连接到的表名,剩余的其它参数则是为连接指定的列约束,当然,正如你所看到的,你可以在单个查询中连接多张表.

$users = DB::table('users')
        ->join('contacts', 'users.id', '=', 'contacts.user_id')
        ->join('orders', 'users.id', '=', 'orders.user_id')
        ->select('users.*', 'contacts.phone', 'orders.price')
        ->get();

三、Where子句
使用查询构建器上的where方法可以添加where子句到查询中,调用where最基本的方法需要三个参数,第一个参数是列名,第二个参数是一个数据库系统支持的任意操作符,第三个参数是该列要比较的值.

$users = DB::table('users')->where('votes', '=', 100)->get();
为了方便,如果只是简单比较列值和给定数值是否相等,可以将数值直接作为where方法的第二个参数:

$users = DB::table('users')->where('votes', 100)->get();
四、Insert插入方法
查询构建器还提供了insert方法来插入记录到数据表。insert方法接收数组形式的列名和值进行插入操作:

DB::table('users')->insert(['email' => 'john@example.com', 'votes' => 0]);
我们甚至可以一次性通过传入多个数组来插入多条记录,每个数组代表要插入数据表的记录:

DB::table('users')->insert([
    ['email' => 'taylor@example.com', 'votes' => 0],
    ['email' => 'dayle@example.com', 'votes' => 0]
]);

五、Update更新
当然,除了插入记录到数据库,查询构建器还可以通过使用update方法更新已有记录。update方法和insert方法一样,接收列和值的键值对数组包含要更新的列,我们可以通过where子句来对update查询进行约束:

DB::table('users')->where('id', 1)->update(['votes' => 1]);

六、Delete删除
查询构建器还可以通过delete方法从表中删除记录:

DB::table('users')->where('id', 1)->delete();

在调用delete方法之前可以通过添加where子句对delete语句进行约束:

DB::table('users')->where('votes', '<', 100)->delete();

如果我们希望清除整张表,也就是删除所有列并将自增ID置为0,可以使用truncate方法:

DB::table('users')->truncate();

内容来源:Laravel学院5.1查询构造器

作者:王羽落
链接:https://www.jianshu.com/p/475c3a329c27
来源:简书

Last modification:April 25, 2022
如果觉得我的文章对你有用,请随意赞赏