首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过 Laravel 查询构建器实现简单的增删改查操作

DB 门面提供的方法执行原生的 SQL 语句,DB 门面既可以用于构建查询构建器方法链,也可以用于原生语句的执行。...使用查询构建器进行增删改查 接下来,我们开始介绍 Laravel 数据库功能的核心组件 —— 查询构建器(说是核心,是因为 Eloquent 模型的底层也是基于这个查询构建器),日常开发中,我们与数据库的交互基本都是直接或间接通过它来完成的...查询构建器也是基于 DB 门面的,只不过需要调用其提供的 table 方法构建一个基于指定数据表的查询构建器。...下面我们就通过查询构建器来依次实现上面通过 DB 门面执行原生 SQL 语句完成的增删改查功能。...,无需手动设置参数绑定来规避 SQL 注入攻击,因为 Laravel 底层会帮助我们自动实现参数绑定,所以推荐使用查询构建器进行数据库操作。

4.2K20

通过 Laravel 查询构建器实现复杂的查询语句

你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...] ])->get(); or查询 在日常查询中,or 条件的查询也很常见,在查询构建器中,可以通过 orWhere 方法来实现: DB::table('posts')->where('id', '查询 NULL 查询就是判断某个字段是否为空的查询,Laravel 查询构建器为我们提供了 whereNull 方法用于实现该查询: DB::table('users')->whereNull(...字段相等查询 有的时候,我们并不是在字段和具体值之间进行比较,而是在字段本身之间进行比较,查询构建器提供了 whereColumn 方法来实现这一查询: DB::table('posts')->whereColumn...分页 日常开发中,另一个常见的查询场景就是分页查询了,在查询构建器中提供了两种方式来进行分页查询。

30.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Laravel的基本数据库操作部分

    [laravel] laravel的数据库配置 找到程序目录结构下.env文件 配置基本的数据库连接信息 DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=blog...DB_USERNAME=root DB_PASSWORD=root 修改完.env文件需要重启服务 [laravel] laravel的数据库入门 控制器中导入DB数据库操作类,use DB 使用DB类的静态方法...select来查询数据库,DB::select(),参数:sql语句,参数值数组 例如:$user=DB::select("select * from article where id=?"...使用DB::table(),得到查询构造器对象,参数:表名 调用Builder对象的get()方法,得到数组数据 例如:$users=DB::table("article")->get(); 查询构造器是链式调用的...create_users_table --create=users 此命令会在database/migrations目录下面创建一个迁移文件 打开生成的迁移文件,在up方法里面进行字段的创建,这里会用到数据库的结构构造器

    1.4K30

    【Laravel系列4.2】查询构造器

    查询构造器 什么是查询构造器?...其实,查询构造器就相当于我们将原始 SQL 的操作进行了一次封装而已。而且,在模型中,其实内部调用的也是这个 查询构造器 。也就是说,查询构造器是介于 模型 和 原始语句 操作中间的一层。...在 查询构造器 中,还有其它很多的链式函数可以实现非常复杂的数据库操作,大家可以自己去研究一下。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...总结 关于 查询构造器 的其它使用在官方文档上都有,今天的文章就只是简单地介绍了一些常用的和独特的查询构造方式而已,毕竟我们的系列文章的主旨还是在分析源码上。

    16.8K10

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    为了演示查询构造器的功能用法,我们直接使用 DB 门面创建 QueryBuilder 对象。...我们引入查询构造器,引入模型,就是为了摆脱繁杂的SQL语法,这里又传入原生语句,不提倡!...举例一些常规的查询: $emails = DB::table('contacts')->select('email', 'email2 as second_email')->get(); select...Carbon::now()->subDay())->get(); 复杂的查询莫过于使用多表联合查询,使用子查询,使用比较绕的or查询,我们对or查询举两个例子, 大家在调试的时候,一定要对自己写的代码打印一下最终生成的...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    1.2K10

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    为了演示查询构造器的功能用法,我们直接使用 DB 门面创建 QueryBuilder 对象。...我们引入查询构造器,引入模型,就是为了摆脱繁杂的SQL语法,这里又传入原生语句,不提倡!...举例一些常规的查询: $emails = DB::table('contacts')->select('email', 'email2 as second_email')->get(); select...Carbon::now()->subDay())->get(); 复杂的查询莫过于使用多表联合查询,使用子查询,使用比较绕的or查询,我们对or查询举两个例子, 大家在调试的时候,一定要对自己写的代码打印一下最终生成的...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    1.8K11

    Laravel5.8学习之数据库操作构造器

    Laravel 的数据库查询构造器为创建和运行数据库查询提供了一个方便的接口。它可用于执行应用程序中大部分数据库操作,且可在所有支持的数据库系统上运行。...Laravel 的查询构造器使用 PDO 参数绑定来保护您的应用程序免受 SQL 注入攻击。因此没有必要清理作为绑定传递的字符串。...Laravel5.8数据库构造器真是比较强大,但是自己更倾向于对原生的SQL语句的撰写,嘿嘿,记一下笔记吧!...::table('user')->first(); //find 读取指定id的数据 $data = DB::table('user')->find(2); /** * select 各种查询 */...// select 选择打印字段 $data = DB::table('user')->select("name",'pass')->get(); /** * 使用where条件 */ $data =

    75110

    【Laravel系列4.6】

    在电商、金融类应用中,事务是非常重要的功能,也是必须的能力。在 Laravel 中操作事务可以说是简单到没朋友。...PDO 属性设置 来填坑了,在【Laravel系列4.2:查询构造器】https://mp.weixin.qq.com/s/vUImsLTpEtELgdCTWI6k2A中,我们说过一个问题,那就是查询构造器查询出来的结果都是...0.002" // ORACLE_NULLS: NATURAL // CLIENT_VERSION: "mysqlnd 5.0.12-dev - 20150407 - $Id: 7cc7cc96e675f6d72e5cf0f267f48e167c2abb23...找到 laravel/framework/src/Illuminate/Database/Connection.php 中的 select() 方法,也就是 原生语句 执行的地方。...之前我们已经说过,查询构造器 最终调用的结果还是使用的 原生查询 的这几个方法,所以我们从这个 select() 方法入手。

    1.4K30

    掌握 Laravel 的测试方法

    接下来我们将创建具体的测试用例,来讲解如何在 Laravel 中使用「单元测试」和「功能测试」。 搭建测试环境 创建测试模型 在开始创建测试用例前,我们需要先构建起用于测试的项目依赖。...= DB::select('select * from posts where id = 1'); $db_post_title = ucfirst($db_post[0]->title...为了实现这样的测试功能,我们通过 DB 类使用原生 SQL 查询到一篇文章,并将文章的标题赋值给 $db_post_title 变量。...select('select * from posts where id = 1'); $db_post_title = ucfirst($db_post[0]->name);...首先,我们还是通过 DB 类使用原生 SQL 查询到一篇文章,并将文章的标题赋值给 $db_post_title 变量。接着我们模拟一个访问 /accessor/index?

    5.7K10

    Laravel 数据库连接配置和读写分离

    今天开始讲如何在 Laravel 中操作数据库,Laravel 为我们提供了多种工具实现对数据库的增删改查,在我们使用 Laravel 提供的这些数据库工具之前,首先要连接到数据库。...默认情况下,我们在通过 Laravel 提供的数据库工具(DB 门面、查询构建器、Eloquent模型)连接数据库的时候,都没有显式指定连接,因为我们在配置文件中指定了默认的连接 mysql。...所以要连接上其它连接很简单,在查询的时候指定这个新的连接就好了,如果你使用的是 DB 门面执行原生 SQL 查询,可以这么连接老的数据库: $users = DB::connection('mysql_old...')->select(...); DB::connection('mysql_old')->insert(...); 如果你使用的是查询构建器进行数据库操作,可以这么指定(和原生操作一样): $users...当然,和多个数据库连接类似,你也可以在使用时显式进行指定,以查询构建器为例: DB::connection('read')->table('users')->where(...)

    5.5K20

    【Laravel系列4.5】主从库配置和语法生成

    但是你要知道的是,Laravel 以及现代化的所有框架都是可以方便地配置主从分离的。另外,我们还要再回去 查询构造器 中,看一下我们的原生 SQL 语句的拼装语法到底是如何生成的。...从这里我们可以看出,Laravel 是根据参数来判断是否使用从库连接进行查询的,而我之前看过其它框架的源码,是 Yii 还是 TP 什么来着,有根据查询语句是否有 SELECT 字符来判断走从库去查询的...其实我们在 查询构造器 那篇文章中就已经看到过 Laravel 是如何生成 SQL 语句了,还记得我们分析的那个 update() 方法吗?...如果不记得的小伙伴可以回去看一下 【Laravel系列4.2】查询构造器https://mp.weixin.qq.com/s/vUImsLTpEtELgdCTWI6k2A 。...总结 今天的内容其实相对来说轻松一些,毕竟关于 Laravel 数据库方面的内容重点在于之前学习过的 模型 和 查询构造器 上。

    4.3K20

    Laravel源码解析之QueryBuilder

    Database 查询构建器 上文我们说到执行 DB::table('users')->get()是由Connection对象执行table方法返回了一个QueryBuilder对象,QueryBuilder...提供了一个方便的接口来创建及运行数据库查询语句,开发者在开发时使用QueryBuilder不需要写一行SQL语句就能操作数据库了,使得书写的代码更加的面向对象,更加的优雅。...上面我们说过在执行 DB::table('users')->where('name','James')->get()时$wheres属性里的值是: public $wheres = [ [...然后在compileSelect方法里将这个由查查询语句里每部份组成的数组转换成真正的SQL语句: protected function concatenate($segments) { return...通过梳理流程我们知道: Laravel是在第一次执行SQL前去连接数据库的,之所以$pdo一开始是一个闭包因为闭包会保存创建闭包时的上下文里传递给闭包的变量,这样就能延迟加载,在用到连接数据库的时候再去执行这个闭包连上数据库

    1.9K50

    ThinkPHP5框架与ThinkPHP3.2的对比区别

    应该庆幸没选择其他框架,什么 CI、YII、Laravel 之类的,Laravel 了解过一些,但是没深入过,还是 TP 系列使用的顺手一些。...toArray方法,许多开发者在all或select尝试使用toArray来转换为数组,在此希望开发者能理解对象的概念,尝试使用对象进行数据的使用,或者使用db方法进行数据库的操作,也提醒一下部分滥用toArray...的开发者,all 或 select 结果是对象的数组集合,是无法使用toArray进行转换的 在 TP3.2 中使用最多的还是 M 和 D 方法,查询find和select用的最多 ---- 命名规范...; } } 3.2 版本控制器命名 IndexController.class.php 5.0 版本控制器命名 Index.php 在控制器中正确的输出模板 5.0 在控制器中输出模板,使用方法如下...的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过 Db 类调用,原来的 M 函数调用可以改用 db 函数,例如: 3.2 版本 M('User')->where(['name'=>

    3.9K20

    laravel 学习之路 数据库操作 查询数据

    DB facade 为每种类型的查询提供了方法: select,update,insert,delete 和 statement。...运行 Select 查询 你可以使用 DB Facade 的 select 方法来运行基础的查询语句我们在上面创建的路由里增加个 index 的路由 dump 是 laravel 的打印函数可以把它理解为...select * from test where testId = :id', ['id' => 1]); dump($binding); } 查询构造器 Laravel 的数据库查询构造器为创建和运行数据库查询提供了一个方便的接口...Laravel 的查询构造器使用 PDO参数绑定来保护您的应用程序免受 SQL 注入攻击。因此没有必要清理作为绑定传递的字符串 注意:PDO 不支持绑定列名。...聚合 查询构造器还提供了各种聚合方法,比如 count, max,min, avg,还有 sum 这些就很简单了 $users = DB::table('test')->count(); $price

    3.2K20

    Laravel Eloquent 模型关联关系(下)

    从性能上来说,渴求式加载更优,因为它会提前从数据库一次性查询所有关联数据,而懒惰式加载在每次查询动态属性的时候才会去执行查询,会多次连接数据库,性能上差一些(数据库操作主要开销在数据库连接上,所以在开发过程中如果想优化性能...另外,如果访问的是模型实例上的 author() 方法时,返回的不是用户实例了,而是一个关联关系实例,该实例注入了查询构建器,所以你可以在其基础上通过方法链的方式构建查询构建器进行更加复杂的查询,我们以一个一对多的查询为例...: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users = User::whereHas('posts', function...', Post::class) ->whereNull('deleted_at'); }); })->get(); 如果不想自己构造查询构建器,还可以通过方法链的方式实现上述同样的功能...有时候,你可能仅仅是想要更新中间表字段值,这个时候,可以通过 updateExistingPivot 方法在第二个参数中将需要更新的字段值以关联数组的方式传递过去: $post->tags()->updateExistingPivot

    19.6K30

    【Laravel系列4.1】连接数据库与原生查询

    连接数据库与原生查询 在 PHP 的学习中,数据库,也就是 MySQL 就像它的亲兄弟一样,永远没法分家。同理,在框架中,数据库相关的功能也是所有框架必备的内容。...Laravel 框架中的 DB 和 ORM 是两个不同的组件,关于 ORM 的概念,我们也将在相关的学习中了解到,但是现在我们先从简单的普通查询学起。...Route::get('rawdb/test/show', function () { dd(\Illuminate\Support\Facades\DB::select("select * from..., ['Sam', 1]); dd(\Illuminate\Support\Facades\DB::connection('laravel8')->select("select * from raw_test...当然,这也是为了框架的通用性,因为 PDO 也是通用的,在工厂中,我们可以看到 Postgres、SQLite、SQLServer 的连接器,如果使用 MySQLi 的话,可就没办法支持这些数据库了哦。

    3.2K50

    laravel 模型Eloquent ORM 查询

    up前面玩了 DB 查询,但是laravel开发基本不怎么使用db方式查询,应该有更强大的 模型 Model 介绍 Laravel 的 Eloquent ORM 提供了一个漂亮、简洁的 ActiveRecord...你可以通过模型查询数据表中的数据,以及在数据表中插入新记录。 在开始之前,请确保在 config/database.php 中配置数据库连接。更多关于数据库配置的信息,请查看 文档。...使用的是单数形式帕斯卡命名法 ,也就是首字母大写的驼峰命名法 比如 up之前创建的 test表 Model 命名就是 Test.php 但是呢, laravel 都能 用命令创建控制器生成表跟数据填充了...现在有了Model 接下来就是 调用他咯 调用 Model up 先创建一个新的控制器 TestMdlController在里面写个index方法 在查询数据的时候经常会有略微复杂的查询把它们写成一个模型方法 比如说在 app/Models/Test.php 文件中写一个 getList 方法 <?

    4.4K10
    领券