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

Laravel 6.11 版本发布,优化了 Redis 多频道广播逻辑

Laravel 官方开发组本周发布了 Laravel 6.11.0 版本,新版本 Eloquent 模型查询时新增 firstWhere 方法,优化了基于 Redis 的多频道广播,以及一些现有版本的问题修复...1、新增功能 Eloquent firstWhere() 方法 Eloquent 模型现在支持调用 firstWhere 方法,它的功效和 where()->first() 一样,算是一个语法糖: /...优化 Redis 多频道广播 Laravel 应用中,一次发送事件到多个频道很常见,目前,我们的做法是通过多个发布命令发送完全一样的负载数据到指定 Redis 服务器,这将导致不必要的数据传输,从而带来通信及性能损耗...所以,最新版本的 Laravel 优化了这个问题, RedisBroadcaster 中添加一段 Lua 脚本,允许一次广播数据到多个频道: 2、更新日志 接下来,我们来大致看一下此次版本更新的详细日志...:makeFaker() 中的未定义属性 修复 Str::afterLast() 方法 修复 PHP 7.3 插入浮点类型到 MySQL 数据库问题 修复通过自定义中间表属性名刷新模型问题 代码调整

1.4K10
您找到你想要的搜索结果了吗?
是的
没有找到

需要掌握的 Laravel Eloquent 搜索技术

本文将带领大家学习 MySQL 和 Eloquent 搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。... Laravel 中可以使用 where 方法实现对给定字段和给定值进行比较查询,就是这样简单。 <?...使用 Like 关键字 如何实现模糊查询呢?即实现 MySQL 的 LIKE 查询。Eloquent 提供了比 where 语句更加灵活的模糊查询功能。...foo 的文章 $result = Post::where('title', 'like', '%{$keyword}%')->get(); 我们可以看到 Eloquent 的模糊查询功能十分灵活。...我们可以 Laravel 里使用 where 语句,可以使用原生 SQL 语句,甚至可以使用模糊查询和相似查询,所有这些查询功能都是 Laravel 内置提供的开箱即用,非常赞!

3.5K10

Laravel代码简洁之道和性能优化

经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...你可以 Eloquent 模型中使用 UPSERT 和 INSERT IGNORE 查询。...->upsert(...); Eloquent 中,所有版本的 LumenHasUpsertQueries都需要该特性。...当然了还是有一些注意点和坑,下面分享一下 注意的问题 要根据需求添加唯一索引 根据官方文档中的说明,我们的model中必须添加这行代码,才能以Eloquent的方式用 use \Staudenmeir\...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库的时间是int类型,不是laravel默认的时间格式,并且我们的插入时间和更新时间也不是laravel默认的字段

5.7K20

需要掌握的 Laravel Eloquent 搜索技术

本文将带领大家学习 MySQL 和 Eloquent 搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。... Laravel 中可以使用 where 方法实现对给定字段和给定值进行比较查询,就是这样简单。 <?...使用 Like 关键字 如何实现模糊查询呢?即实现 MySQL 的 LIKE 查询。Eloquent 提供了比 where 语句更加灵活的模糊查询功能。.../ 获取包含 foo 的文章 $result = Post::where('title', 'like', '%{$keyword}%')->get(); 我们可以看到 Eloquent 的模糊查询功能十分灵活...我们可以 Laravel 里使用 where 语句,可以使用原生 SQL 语句,甚至可以使用模糊查询和相似查询,所有这些查询功能都是 Laravel 内置提供的开箱即用,非常赞!

4.3K20

如何使用 Laravel Collections 类编写神级代码

现在的代码不仅顺畅不少,并且方法实现时无需借助注释告诉我们它们处理什么问题。 不过,还存在一个问题阻止我们的代码不如完美阶段......扩展集合(Extending Collections) Collection 类,同其它 Laravel 组件一样,支持宏(macroable),就是说你可以给它添加方法随后使用。...if 语句中使用不超过两个条件语句,因为我认为超过 2 个条件语句回事代码难以阅读。...如果你计划让它们可以 Eloquent 集合上使用,你需要在此场景下做相应的代码处理才行。...查看官方文档获取更多这个迷人的类库的使用细节:https://laravel.com/docs/collections 提示: 你还可以获取这个 Collection 类独立安装包,使用非 laravel

2.1K20

CVE-2021-39165: 从一个Laravel SQL注入漏洞开始的Bug Bounty之旅

', 'LIKE', '%example%'] ]); // 生成的WHERE条件是:WHERE id > 18 AND title LIKE '%example%' 那么,思考下面三个代码Laravel..., 'LIKE', '%example%'] ]); 所以,通过这个方法,我可以做到了一件事情:从控制where()的第一个参数,到能够完整控制where()的所有参数。...这个boolean既不是SQL语句中的“键”,也不是SQL语句中的“值”,而就是SQL语句的代码,如果没有校验,一定存在SQL注入。 事实证明,这里并没有经过校验。...我添加了一个内容是{{ 233 * 233 }}的Incident Template,渲染结果被成功返回API的结果中: Twig是PHP的一个著名的模板引擎,相比于其他语言的模板引擎,它提供了更安全的沙盒模式...原生View模板引擎中的全局变量

66920

3分钟短文 | Laravel复杂SQL超多WHERE子句,本地作用域你没用过

Laravel提供的 eloquent orm 使用面向对象的方式封装了PDO数据库操作,使用起来非常方便,对于复杂的SQL操作也游刃有余。...今天说一说,复杂的超多的WHERE子句,怎么写起来较为优雅。 学习时间 比如对于业务逻辑中,User模型筛选查询的时候有非常多的限制条件,类似下面这样的: ?...拿“全局作用域”来说,它可以给模型的查询都添加上约束。Laravel 的软删除功能就是利用此特性从数据库中获取 “未删除”的模型。...那么使用 User::all() 方法构造查询时,生成的sql语句中会追加 AgeScope 设置的查询约束条件: select * from `users` where `age` > 200 实现本地作用域...就是在对应的 Eloquent 模型方法前添加 scope 前缀,模型中构造如下的作用域方法: ?

2.7K10

详解laravel中blade模板带条件分页

答: Blade模板是Laravel提供一个既简单又强大的模板引擎; 和其他流行的PHP模板引擎不一样,他并不限制你视图里使用原生PHP代码; 所有Blade视图页面都将被编译成原生的PHP代码并缓存起来...Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的、易于使用的、基于数据库结果集的分页。分页器生成的 HTML 兼容 Bootstrap CSS 框架。...基本使用 基于查询构建器进行分页 有多种方式实现分页功能,最简单的方式就是使用查询构建器或 Eloquent 查询提供的 paginate 方法。...包含视图 被包含的视图可以引用父视图定义的所有变量。...-- 包含视图 -- @include("child" , [ "other" = "额外数据" ]) 总结 到此这篇关于laravel中blade模板带条件分页的文章就介绍到这了,更多相关laravel

7.2K30

laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

本文实例讲述了laravel框架数据库操作、查询构建器、Eloquent ORM操作。...方法可以添加数据库查询条件,where()接收三个参数:字段名、操作符、值,操作符如果是’=’可以省略,例如查询id =1003的数据: $res=DB::table('student')- where...Laravel内置的Eloquent ORM提供了一种便捷的方式帮助你组织数据库数据,每张数据表都对应一个与该表进行交互的模型(Model),通过Model类,你可以对数据表进行查询、插入、更新、删除等操作...如果需要自定义表名,则需要重写$table变量来指定表名。 Eloquent默认的主键为’id’,且该字段为自增int型,如果需要自定义主键,可以通过$primaryKey来指定。...使用create批量添加时,需要在模板中通过fillable指定可以赋值的字段,也可以guard指定不允许赋值的字段。

13.3K51

laravel 模型Eloquent ORM 查询

up前面玩了 DB 查询,但是laravel开发基本不怎么使用db方式查询,应该有更强大的 模型 Model 介绍 LaravelEloquent ORM 提供了一个漂亮、简洁的 ActiveRecord...laravel 的 Model 使用先进的 Eloquent ORM 但也有优缺点 优点是数据库的操作变的简单安全 缺点也明显数据库的操作变的缓慢笨重 Eloquent ORM 作为 laravel 中亮点...但是却报错了我们看到model生成的sql 莫名其妙拼接了一个 s 这里我百度了一下 artisan 生成的model 若没有特别指定,laravel系统会默认自动对应名称为「Eloquent类名称的小写复数形态...'test'; ``` 第二种添加自定义的Eloquent基类 BaseModel 黑科技可以永绝后患 <?...但是有点写法可能不太明白这种类名跟一个变量直接当参数传给方法的 function index(Test $testMdl) laravel 中大量使用了这种方法,百度了下才知道这个东西叫做 依赖注入 。

4.4K10

3分钟短文:Laravel 从软删除说到模型作用域的概念

所以引入了软删除的概念,就是表内添加一个字段,用于标记,这一行条目是否算是删除状态。laravel中, 这个软删除字段默认是 deleted_at。你也可以模型中手动指定。...: $activeVips = Contact::activeVips()->get(); 实现此方法,很简单,只需模型文件内添加如下方法: class Contact extends Model{...声明一个全局作用域很简单,只需模型文件内添加如下代码: class Contact extends Model{ protected static function boot() {...一下节省了很多冗余的代码。 如果你的全局作用域写的逻辑会有点多喝复杂,可以将其独立出来,写成类,以便调用。...', true); }} 模型 Contact 内调用: use App\Scopes\ActiveScope;use Illuminate\Database\Eloquent\Model;class

1.3K30

Laravel5.2之Demo1——URL生成和存储

在这里使用laravelcollective/html这个组件,顺便了解下怎么laravel中安装组件。 这里书中使用了laravel4.*自带的Form类,但laravel5....通过composer安装也很简单,就是项目根目录下的composer.json文件'require'数组中添加"laravelcollective/html": "5.2....这里注意下:如果不写table变量laravel会自动根据model名字复数来找数据表,如这个model名字是link,那就找links表。...模板视图中得到$titletitle变量可以这么做,Session::get('titletitle'),检查有无变量这么做Session::has('titletitle') } 然后postUrl...blade视图模板中可以直接引用就不用Session::get()了,这是因为laravel会自动把这个变量和视图模板绑定,这errors是个特殊的变量form.blade.php视图中添加上验证错误信息代码

24K31

orm 系列 之 Eloquent演化历程2

中一大亮点Artisan,Artisan是 Laravel 自带的命令行接口名称,此处不做具体的介绍了,有机会再细说的,当我们命令行中执行php artisan command的时候,会去调用migrateCommand...本文最后讲下Eloquent中新增的对象之间的关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 表结构 多态关联允许一个模型单个关联下属于多个不同模型...让我们跟着git继续追踪吧_ 新纪元 为了解决PHP组件管理及散步的问题,2009年的php|tek大会上成立了PHP-FIG组织,目的在于透过三个方式来制定PHP社群开发组件时的规范,laravel...User extends Eloquent { // } 此处Eloquent已经通过初始化设置了静态变量$resolver,我们可以方便的获取连接Connection了,也就是有了数据库操作的功能...参考 [ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系

2.4K30

Laravel基础

一、Laravel核心目录文件介绍 app:程序的核心代码和业务逻辑代码,其中的Http目录是我们业务逻辑的存放点 bootstrap:包含框架启动的和自动加载文件 config:包含所有程序中的配置文件...{id}',[‘uses’=>控制器名称@控制器下的方法]) 2.3 视图 - 使用模板 直接在控制器里面调用view然后return返回即可 return view(路径/模板, [待传入的变量...里所表达的内容 可以将其假设为一个占位符用子模版去实现它 区别: yield是不可扩展的(因为他只声明定义了一个视图片段没有任何内容) section既定义了视图片段,也可以有内容,还可以被子模版扩展 view...4.2 基础语法与include的使用 模板中输出php变量 {{ $name }} 模板中执行php代码 {{ date('Y-m-D H:i:s', time()) }} 模板中强制输出 @{{...$name }} 字符串 @{{ $name }} 模板注释格,不会在查看源代码中显示,和html注释的区别 {{-- 模板注释 --}} 视图引用 include @include('common1

7.7K30

Laravel学习笔记之Artisan命令生成自定义模板的方法

备注:个人平时写Repository代码时会这样写,如先写上ShopRepositoryInterface并定义好接口方法如all()、create()、update()、delete()、findBy...function findBy($field, $value, $columns = array('*')) { $$model_name = $this- $model_var_name- where...'); } private function createClass() { //渲染模板文件,替换模板文件中变量值 $templates = $this- templateStub(); $class...Collection|static[] */ public function findBy($field, $value, $columns = array('*')) { $Shop = $this- shop- where...就像Laravel自带了很多模板生成命令,用起来会节省很多时间。这是作者平时开发中遇到的问题,通过利用Laravel Artisan命令解决了,所以Laravel还是挺好玩的。

1.9K20
领券