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