前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >3分钟短文:Laravel 使用DB门面操作原生SQL

3分钟短文:Laravel 使用DB门面操作原生SQL

作者头像
程序员小助手
发布2020-09-10 14:50:57
2K0
发布2020-09-10 14:50:57
举报
文章被收录于专栏:程序员小助手程序员小助手

引言

我们推荐使用laravel的eloquent orm 模型操作数据库表, 因为特性更为丰富,组装更为灵活,在编程层面操作数据的来来去去非常直观。而有些场景不可避免地与原生交互,我们本期就来梳理一下DB门面相关的那些方法。

学习时间

系统提供了DB门面用于原生的SQL操作,在程序内引入下面的类:

代码语言:javascript
复制
use Illuminate\Support\Facades\DB;

该类的定义很简单,标准的门面注册方法:

代码语言:javascript
复制
class DB extends Facade
{
    protected static function getFacadeAccessor()
    {
        return 'db';
    }
}

仅实现了 getFacadeAccessor 方法,这些类处于同一个命名空间下的 Facade.php 文件内。

DB门面既可以使用query builder的链式操作,也可以用于执行原生查询。举几个例子。比如删除users表:

代码语言:javascript
复制
DB::statement('drop table users');

带参数绑定的SQL查询语句:

代码语言:javascript
复制
DB::select('select * from contacts where validated = ?', [1]);

或者使用链式操作,获取所有满足条件的记录:

代码语言:javascript
复制
$users = DB::table('users')->get();

当然了,还有经常用到的多表联合查询,复杂的查询过滤条件:

代码语言:javascript
复制
DB::table('users')
    ->join('contacts', function ($join) {
        $join->on('users.id', '=', 'contacts.user_id')->where('contacts.type', 'donor');
    })
    ->get();

CRUD

上一节是一些简单示例,下面我们说一说增删改查的用法。先说查询语句, 如果在数据库优化上做的比较好的一些SQL固定写法,可以使用原生方法固化下来。比如简单的:

代码语言:javascript
复制
$users = DB::select('select * from users');

该方法会返回一个标准对象的集合。扩展一下,带有查询条件的SQL原生语句, 为了防止SQL注入,使用参数绑定的方式:

代码语言:javascript
复制
$usersOfType = DB::select('select * from users where type = ?', [$type]);

当然也可以使用PDO常用的方式占位:

代码语言:javascript
复制
$usersOfType = DB::select('select * from users where type = :type', ['type' => $userType]);

插入新数据,其实与上述的带有占位符参数绑定的SQL查询语句类似,只是SQL语法不同而已:

代码语言:javascript
复制
DB::insert('insert into contacts (name, email) values (?, ?)', ['salt', 'salt@lot.com']);

更新数据也是一样的:

代码语言:javascript
复制
$countUpdated = DB::update('update contacts set status = ? where id = ?', [1, $id]);

当然了,删除语句仅仅需要where子句的条件参数绑定,其他与查询select无异:

代码语言:javascript
复制
$countDeleted = DB::delete('delete from contacts where archived = ?', [1]);

写在最后

本文通过对laravel DB门面的增删改查用法,向大家展示了基本的参数绑定的用法。一般我们不推荐使用原生SQL语句操作数据库,提倡大家把数据库操作集中到模型层, 充分利用eloquent orm的性能。

Happy coding :-)

我是@程序员小助手,持续分享编程知识,欢迎关注。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-09-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员小助手 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 引言
  • 学习时间
  • CRUD
  • 写在最后
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档