Laravel 执行原生 SQL 查询
运行原生 SQL 查询
一旦你配置好数据库连接后,就可以使用DB 门面来运行查询。DB 门面为每种查询提供了相应方法: select , update , insert , delete , 和statement 。
运行 Select 查询
运行一个最基本的查询,可以使用DB 门面的select 方法:
<?php
namespace AppHttpControllers;
use DB;
use AppHttpControllersController;
class UserController extends Controller{
/**
* 显示用户列表
*
* @return Response
*/
public function index()
{
$users = DB::select('select * from users where active = ?', [1]);
return view('user.index', ['users' => $users]);
}
}
传递给select 方法的第一个参数是原生的 SQL 语句,第二个参数需要绑定到查询的参数绑定,通常,这些都
是where 字句约束中的值。参数绑定可以避免 SQL 注入攻击。
select 方法以数组的形式返回结果集,数组中的每一个结果都是一个 PHP StdClass 对象,从而允许你像下面
这样访问结果值:
foreach ($users as $user) {
echo $user->name;
}
使用命名绑定
除了使用? 占位符来代表参数绑定外,还可以使用命名绑定来执行查询:
$results = DB::select('select * from users where id = :id', ['id' => 1]);
运行插入语句
使用DB 门面的insert 方法执行插入语句。和select 一样,改方法将原生 SQL 语句作为第一个参数,将
绑定作为第二个参数:
DB::insert('insert into users (id, name) values (?, ?)', [1, 'Dayle']);
运行更新语句
update 方法用于更新数据库中已存在的记录,该方法返回受更新语句影响的行数:
$affected = DB::update('update users set votes = 100 where name = ?', ['John']);
2.5 运行删除语句
delete 方法用于删除数据库中已存在的记录,和update 一样,该语句返回被删除的行数:
$deleted = DB::delete('delete from users');
运行一个通用语句
有些数据库语句不返回任何值,对于这种类型的操作,可以使用DB 门面的statement 方法:
DB::statement('drop table users');
文章参考来源:http://www.golaravel.com/。(文章仅作学习使用,如有版权问题请联系管理员删除)
本文链接二维码可以保存在本地:保存
http://shixiangcun.cc/index.php?c=index&id=34&m=articleDetailInfo
分类 Laravel | 浏览 (146637) | 赞 (0) | 踩 (0) | | 2016-04-29 10:21:06 |
相关文章
- Mac安装Swoole扩展phpize 时 Cannot find autoconf 解决方法
- mac下安装swoole扩展报错PHP Startup Unable to load dynamic library
- Laravel 数据库事务
- PHP贷款等额本息、等额本金计算月供还款计划公式
- Laravel 关闭过滤排除部分路由VerifyCsrfToken 验证
- Laravel Horizon监控Redis队列queue