首页
学习
活动
专区
圈层
工具
发布

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

查询小技巧 我们首先来介绍几个 Laravel 自带的语法糖,可以帮助我们快速获取期望的查询结果,提高编码效率。...有时候,我们想要获取的并不是一行或几行记录,而是某个字段的值,你当然你可以查询到一行记录后从结果对象中获取指定字段的值,但是 Laravel 为我们提供了更便捷的语法: $name = '学院君'; $...你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...like查询 有时候我们可能会对字段进行模糊查询,尤其是字符串匹配的时候: DB::table('posts')->where('title', 'like', 'Laravel学院%')->get()...null查询 NULL 查询就是判断某个字段是否为空的查询,Laravel 查询构建器为我们提供了 whereNull 方法用于实现该查询: DB::table('users')->whereNull(

32.8K20

在Laravel中使用数据库事务以及捕获事务失败后的异常

Description 在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...方法来提交这个事务: DB::commit(); 注意: DB facade 的事务方法也可以用来控制 查询语句构造器 及 Eloquent ORM 的事务。...: 考点知识点关联表 wiki_tag_rel 现在要开启事务新增Wiki数据,新增wiki成功后再把它关联到指定的考点上去 (在laravel中使用查询构建器或者Eloquent ORM执行query...\Database\QueryException; use App\Wiki; class TestController extends Controller { //用DB facade的事务方法控制...查询语句构建器的事务 public function storeWiki(Request $request) { DB::beginTransaction();

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

    Laravel如何使用数据库事务及捕获事务失败后的异常详解

    前言 如果大家在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...(); 注意: DB facade 的事务方法也可以用来控制 查询语句构造器 及 Eloquent ORM 的事务。...Wiki数据,新增wiki成功后再把它关联到指定的考点上去 (在laravel中使用查询构建器或者Eloquent ORM执行query时,如果失败会返回 IlluminateDatabaseQueryException...IlluminateDatabaseQueryException; use AppWiki; class TestController extends Controller { //用DB facade的事务方法控制...查询语句构建器的事务 public function storeWiki(Request $request) { DB::beginTransaction(); try { $tagIds = explode

    2.3K30

    基于 Laravel 的用户动态模块开发

    概念抽象 用户动态,顾名思义,动态的产生,就是一系列事件的历史记录,所以首先关注“事件”这个名词,它有哪些属性: 触发者,基于社区所有的事件几乎都是由用户触发的 事件主体,事件的主体信息,例如“xxx发布了文章...怎么展示 我们的动态展示需求通常有以下几种: 我的好友的动态 某个人的动态,通常是个人中心 全部动态,比如 Laravel China 首页的全部动态 动态搜索,比较少见 我最近正在开发 EasyWeChat...在事件属性里记录关键信息 看到上面记录动态的时候你可能会问,只存储了 ID,这种多态关联,查询的时候会比较复杂,比如,我们要将动态显示为: 安小超 发布了文章 《自定义菜单的使用》 我们如果只是存储了文章的...id 与类型,我们还需要查询一次文章表,才能得到标题用于显示,这样一个动态列表的话,可能会几十条 SQL 了,的确是这样的,我的解决方案是这样的: 其实我们的用户动态是不要求 100% 精准的,所以,...关于好友动态部分的实现,根据你的应用量级,以及好友关系的存储各有不同,大家自己集思广益即可,大部分都是先查好友关系再查动态,关联查询也可以,自己实现吧。

    2.1K30

    基于RocketMq的事务消息设计

    4.如果提交或者回滚消息丢失或者Producer执行本地事务期间挂起,Broker会给同一组类的所有producer发送check消息,确认事务最终状态 5.Producer会根据本地事务状态回复提交...Rocketmq为了抽象存储的底层实现,所有事务性消息操作都集中在事务服务接口上。...RocketMQ提供了一个带有自己的存储系统的默认实现,我们使用事务桥来实现我们的事务存储逻辑,而不是直接修改RocketMQ的存储层。 发送事务消息 ?...发送事务消息时序图,以及事务消息是如何两阶段提交的。 事务消息校验 ?...事务消息检验逻辑时序图,如果事务消息一直处于Half(Prepare)Message status,Broker就会向producer发送确认消息,验证事务消息的最终状态。

    65230

    基于 PHPStorm 编辑器的 Laravel 开发

    引言 本文主要讲述在PHPStorm编辑器中如何使用PHPStorm的Laravel插件和Laravel IDE Helper来开发Laravel程序,结合个人积累的一点经验来说明使用PHPStorm编辑器来开发程序还是很顺手的...,内容主要基于PHPStorm官方文档《Laravel Development using PhpStorm》 。...学习主题 本文主要涉及以下几个技巧: Composer的初始化 Laravel IDE Helper的安装 Laravel Plugin的安装 PHPStorm对Laravel框架的支持 PHPStorm...对Blade模板引擎的支持 使用PHPStorm调试Laravel程序 使用PHPStorm调试Laravel程序 使用PHPStorm的单元测试功能 使用PHPStorm的数据库功能 1、一些准备工作...3、使用Xdebug来调试Laravel程序 Xdebug是调试PHP程序的神器,尤其在调试Laravel代码时会非常有用。

    4.9K80

    基于 Pusher 驱动的 Laravel 事件广播(下)

    说明:本部分主要基于三个示例来说明Pusher服务的使用。 基础 Channels:频道用来辨识程序内数据的场景或上下文,并与数据库中的数据有映射关系。...就像是听广播的频道一样,不同频道接收不同电台。 Event:如果频道是用来辨识数据的,那事件就是对该数据的操作。...在项目根目录安装laravel/socialite包: composer require laravel/socialite 获取github密钥 登录github 进入Setting->OAuth.../laravelpusher.app:8888/activities后在输入框内填写文本,如在B页面填写'Laravel is great!!!'...好,现在自己与自己开始聊天,打开两个页面,作者的环境里路由为http://laravelpusher.app:8888/chat(这里输入你自己的路由就行): 总结:本部分主要以三个小示例来说明Laravel

    3.6K31

    Spring事务的介绍,以及基于注解@Transactional的声明式事务

    不可重复读: 一个事务执行相同的查询两次或两次以上,每次都得到不同的数据。如:A事物下查询账户余额,此时恰巧B事物给账户里转账100元,A事物再次查询账户余额,那么A事物的两次查询结果是不一致的。...当两个或多个事务查询相同的记录,然后各自基于查询的结果更新记录时会造成第二类丢失更新问题。每个事务不知道其它事务的存在,最后一个事务对记录所做的更改将覆盖其它事务之前对该记录所做的更改。...{ /** * 返回该事务是否在内部携带保存点,也就是说,已经创建为基于保存点的嵌套事务。...基于@Transactional注解的声明式事务 其底层建立在AOP的基础之上,对方法前后进行拦截,然后在目标方法开始之前创建一个或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。...通过声明式事务,无需在业务逻辑代码中掺杂事务管理的代码,只需在配置文件中做相应的事务规则声明(或通过等价的基于标注的方式),便可以将事务规则应用到业务逻辑中。

    62220

    基于Container Event容器事件的Laravel WEB APP

    说明:本文主要讲述Laravel容器事件,并更根据容器事件做一个简单demo供加深理解容器事件。同时,作者会将开发过程中的一些截图和代码黏上去,提高阅读效率。...Container是Laravel框架的核心,Container中储存着各种各样的Service,并且每一个Service通过Service Provider注册在Container里,通过Facade...当输入错误时会提示错误信息: Container Event就是在Service对象从容器中解析注入前触发事件,可以利用这个功能做一些有趣又好用的好东西呢,比如Laravel框架的表单请求验证就是这么做的...总结:本节主要讲述Laravel的容器事件,并以Form Requet为例说明它的用途,同时以一个小demo讲述怎么一步步建立并监听容器事件。...嘛,过两天还想结合Laravel的Task Scheduler任务调度新开篇章,到时见。

    1.5K21

    基于Model Event模型事件的Laravel实时APP

    说明:本文主要来源于real-time-apps-laravel-5-1-event-broadcasting 本文主要基于Laravel的Model Event介绍该框架的实时通信功能,Laravel...Pusher包,有关Pusher的注册和使用相关信息可以参考:(基于 Pusher 驱动的 Laravel 事件广播)(上)。...、注册和安装可参考:基于 Pusher 驱动的 Laravel 事件广播(上) 注册安装也比较简单,总之使用Pusher能做个实时APP。...想要了解更多可以参考这篇文章:(基于 Pusher 驱动的 Laravel 事件广播)(下) 测试实时功能 刷新AB页面,并观察数据库model_event.items。 测试实时创建功能。...总结:本节主要利用Laravel的Model Event来创建一个实时WEB APP,挺好玩的,可以玩一玩哦。有问题可留言。

    6.7K31

    基于Spring的转账事务管理

    String targetName, Float money) { System.out.println("transfer...."); //2.1根据名称查询转出账户...,每次accountDao方法调用都会从数据库连接池中拿出一个connection 连接,然后执行方法,自动commit提交,中间如果出从,可能会导致转入账户加钱,而转出账户却没有减钱,事务无法回滚的错误...2.线程绑定connection 因为要让事务控制多个accountDao方法共同提交或则共同回滚,因此只能使用同一个connection。当前线程是唯一的,因此可以绑定在线程上。...3.事务管理的工具类 为了便于service层代码业务逻辑的清晰,将会单独写一个事务管理的工具类 /** * 和事务管理相关的工具类,它包含了,开启事务,提交事务,回滚事务和释放连接 */ @Component...基于Spring的转账事务管理到此就完成了,如果有不懂的地方欢迎留言一起探讨

    52250

    ES 基于查询结果的聚合

    在了解本文内容前,必须先了解ES DSL查询和ES 聚合查询,ES基于查询结果的聚合分为两种,第一种类似与关系型数据库中的Having语法,第二种类似于关系型数据库中先where在group by的语法...,本文主要分析先查询后聚合场景 演示数据从ES 聚合查询获取 1、先查询后聚合 现在需要统计价格在50到500价格范围区间的所有食物,并按照标签进行聚合查询,代码如下: GET food/_search...{ "key" : "水果", "doc_count" : 2 } ] } } } hits中是按照query查询的结果集...,下面是根据query的结果集进行的聚合查询. 2、先聚合后查询(注意这里不是having语法,而是查询聚合里面的详情) 通过post_filter实现 现在需要查询价格范围在50到500之间,按照标签分组之后...,嵌套查询 现在需要统计指定范围内食品的平均值、最大值等等,最后需要带上一个所有食品的平均值.这个时候计算所有食品的平均值不能受限于查询条件,实现方式如下: GET food/_search { "

    2.3K30

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

    ,没有特别说明的话,我们的所有教程都基于 MySQL。...由于 Laravel 数据库功能底层基于 PHP 的 PDO 实现,因此我们可以借助 PDO 的参数绑定功能来防范 SQL 注入,所以对于指定查询条件的 SQL 查询语句,可以这么实现: $name =...使用查询构建器进行增删改查 接下来,我们开始介绍 Laravel 数据库功能的核心组件 —— 查询构建器(说是核心,是因为 Eloquent 模型的底层也是基于这个查询构建器),日常开发中,我们与数据库的交互基本都是直接或间接通过它来完成的...查询构建器也是基于 DB 门面的,只不过需要调用其提供的 table 方法构建一个基于指定数据表的查询构建器。...,对于更加复杂的查询操作(连接、分页、子查询等),以及数据库事务的实现,我们将在下一篇教程中展开。

    5.3K20

    通过 Laravel Sail 构建基于 Docker 的本地开发环境

    Laravel 官方最近发布了 Laravel Sail —— 一个轻量级的、基于 Docker 的 Laravel 本地集成开发环境,今天学院君就以 Mac 系统为例,给大家演示下如何基于 Laravel...首先,通过如下全新的安装命令初始化一个新的 Laravel 项目 redis-demo(项目名称可任意设置): curl -s https://laravel.build/redis-demo | bash...Sail 本质上是基于 Docker Compose 编排的 Docker 容器服务构建起来的 Laravel 集成开发环境(包含 PHP、MySQL、Redis),只不过针对 Laravel 项目做了上层封装和兼容...,你不需要了解任何关于 Docker 容器的知识,就可以通过 Sail 文档提供的命令满足日常开发需求,这极大降低了基于 Docker 搭建 Laravel 本地开发环境的入门门槛。...所有容器服务启动成功后,就可以在浏览器中通过默认的 laravel.test 域名来访问这个新建的项目了: ?

    3.4K20

    基于Spring JDBC的事务处理

    基于Spring JDBC的事务处理 事务(Transaction):在数据库中,可以保持一系列的数据操作要么全部执行成功,要么全部执行失败的机制!...在基于Spring JDBC的编程中,只需要为业务方法加上@Transactional注解,就可以使得该业务方法中的多条数据操作是有事务的保障的,这多条数据操作要么全部成功,要么全部失败,不会出现成功一半且失败一半的问题...框架在处理“事务”时,其大致的执行方式是: try { 开启事务(BEGIN) 执行一系列的数据操作 提交事务(COMMIT) } catch (RuntimeException e) { 回滚事务...(ROLLBACK) } 所以,在基于Spring JDBC的编程中,需要注意: 如果某个业务涉及2次或2次以上的增删改(例如2次UPDATE操作,或1次INSERT与1次DELETE,或其它)操作,必须在业务方法的声明之前添加...课后,可自行了解:事务的ACID特性,事务的传播,事务的隔离。

    36410

    基于独立的 Laravel Eloquent 组件编写 ORM 模型类

    这里,我们选择使用更加简单的 Active Record 模式来实现 ORM 模型类,并且为了简化流程,我们直接基于 Laravel 框架的 Eloquent ORM 组件来编写,就不再重复造轮子了。...下载 Eloquent ORM 相关扩展包 Eloquent ORM 作为 Laravel 框架自带的 ORM 实现,还可以在 Laravel 框架之外作为独立的 ORM 组件使用。...提供的数据库查询构建器功能,则不需要这些操作)。...$album = $post['album']; ... } } 这里的模型类方法和关联查询都可以在 Eloquent 官方文档查询到,这里不详细介绍了,需要注意的是,我们之前在视图模板中都是通过关联数组获取数据库查询结果...MVC 模式在博客应用中的落地,下篇教程,我们将探索如何通过现代工程化的方式管理前端资源和依赖,我们将引入 NPM、Webpack、Laravel Mix、jQuery 和 Bootstrap,并基于这些工具和框架替换博客应用主题

    3.5K10
    领券