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

在eloquent模型上的setConnection()之后,Laravel分页不起作用

在 Laravel 中,使用 Eloquent 模型进行数据库操作是非常常见的。而 setConnection() 方法用于设置当前模型操作的数据库连接。

当你在使用 setConnection() 方法切换数据库连接后,可能会导致 Laravel 分页功能失效的问题。这是因为 Laravel 的分页功能是基于查询构建器(Query Builder)实现的,而不是直接基于模型实现的。而 setConnection() 方法只是修改了当前模型的数据库连接,并不会影响查询构建器的连接。

要解决这个问题,你可以在进行分页之前,手动切换回原来的数据库连接。可以使用 on() 方法来切换连接,将连接名称作为参数传递给它。具体的代码示例如下:

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

// 在设置完数据库连接后,先保存原连接名称
$originalConnection = YourModel::getConnectionName();

// 切换回默认连接
YourModel::on($originalConnection)->paginate(10);

这样就可以保证在切换数据库连接后,分页功能仍然有效。

需要注意的是,这只是一种解决方案,具体应根据实际需求进行调整和优化。同时,Laravel 也提供了其他的分页扩展库,如 spatie/laravel-eloquent-paginatelaravel-shift/blueprint,可以根据实际情况选择使用。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Laravel源码解析之Eloquent Model

这篇文章我们来学习Laravel Database地另外一个重要的部分: Eloquent Model。...加载Eloquent Builder Eloquent Builder是在上文说到的Query Builder的基础上实现的,我们还是通过具体的例子来看,上文用到的: DB::table('user')...Model写入 刚才说通过Eloquent Model获取模型时(在 newFromBuilder方法里)会把Model实例的 exists属性设置为true,那么对于新建的Model实例这个属性的值是...是在Query Builder的基础上做了进一步封装, Eloquent Builder会把这些CRUD方法的调用转给Query Builder里对应的方法来完成操作,所以在Query Builder里能使用的方法到...除了对数据表、基本的CRUD的抽象外,模型另外的一个重要的特点是模型关联,它帮助我们优雅的解决了数据表间的关联关系。我们在之后的文章再来详细看模型关联部分的实现。

2.3K50

3分钟短文 | Laravel同时连接多个数据库,你用啥办法?

引言 在巩固了基础知识之后,我们把目标转向框架的学习。Laravel 是一个全球流行的框架,开发者和使用者都比较活跃,周边有许多库,和第三方资源均提供了支持。...也丧失了 Eloquent ORM 的强大功能。...所以我们使用模型操作数据库,那么指定某个 Model 使用哪个数据库的哪个表,只需要在模型文件内显式声明: class SomeModel extends Model { protected $...Laravel 的灵活还不止这一点半点,如果在Model内不指定$connection,你还可以在控制器内,在命令行程序内,在队列内,在中间件内,在监听器内,都可以任意指定某个Model连接: class...写在最后 本文通过多种方法,演示了Laravel从数据库连接配置,到程序内使用的方方面面。还没有体验这个框架的同学,你真的值得一试了。 Happy coding :-)

1.4K10
  • 竟然有人质疑我还在用Laravel开发?别忘了PHP是最好的语言。(2)模型工厂类

    组件,Tailwind 分页视图, 时间测试助手,artisan serve 的改进,事件监听器的改进,以及各种其他错误修复和可用性改进,对 Laravel 7.x 继续进行了改善。...模型类目录 由于压倒性的社区需求,现在默认的 Laravel 框架包含一个 app/Models 目录。我们希望你喜欢 Eloquent 的新家!...所有相关的生成器命令均已更新,假定模型存在于 app/Models 目录(如果存在)。如果该目录不存在,则框架将假定你的模型应放置在 app 目录。...除此之外,你也可以给你的 Eloquent 模型工厂添加任意你需要的工具类。.../legacy-factories 扩展包,可以在 Laravel 8 中支持以前的模型工厂。

    2.8K41

    Laravel5.8学习日常之分页

    传统分页 在平常的代码撰写中,分页是一个比较头疼的一件事,总结一下,现在分页可以分为两种分页大类,分别是后端分页及前端分页。...后端分页分为页面有刷新请求及无刷新请求(Ajax请求),就是前台采用按钮事件或者Ajax请求的方式,告知后台进行分页,同时后台进行计算偏移量及当前页码,进行对应页码数据的请求,之后后台查询好数据进行向前台数据进行传递...Laravel分页 Laravel分页是典型的后台分页,不过它将分页进行了封装,只需要调用它封装好的数据就可以实现分页。 数据分页有几种方法。...Laravel 的分页器将 查询构造器 和 Eloquent ORM 结合起来,提供了方便、易用的数据库结果集分页。通过分页器生成的 HTML 兼容 Bootstrap CSS 框架。...laravel文档介绍 Laravel分页只需要两个步骤: (1)控制器初始化方法增加paginate方法,向前台渲染数据即可; (2)前台将添加一个Laravel自带的语法{{ $data->links

    2.2K10

    竟然有人质疑我还在用Laravel开发?别忘了PHP是最好的语言。

    组件,Tailwind 分页视图, 时间测试助手,artisan serve 的改进,事件监听器的改进,以及各种其他错误修复和可用性改进,对 Laravel 7.x 继续进行了改善。...模型类目录 由于压倒性的社区需求,现在默认的 Laravel 框架包含一个 app/Models 目录。我们希望你喜欢 Eloquent 的新家!...所有相关的生成器命令均已更新,假定模型存在于 app/Models 目录(如果存在)。如果该目录不存在,则框架将假定你的模型应放置在 app 目录。...除此之外,你也可以给你的 Eloquent 模型工厂添加任意你需要的工具类。.../legacy-factories 扩展包,可以在 Laravel 8 中支持以前的模型工厂。

    2.5K60

    Laravel 6.7.0 版本发布,支持不加载关联关系

    Laravel 开发团队本周发布了 v6.7.0 版本,新增了一些新特性,以及对之前版本问题的修复。...1、新增特性一览 下面我们对其中一些比较值得关注的代码调整做简单的介绍: Eloquent 模型类中引入的 HasTimestamps Trait 新增了两个方法用来返回完整的创建和更新时间字段名(包含表名...,此更新无需调整任何上层业务代码: 此外,一个比较重要的更新是 Eloquent 模型类现在还新增了 withoutRelations() 方法,用来支持在队列任务中不加载关联关系,从而提高性能。...我们可以在队列任务的构造函数中调用该方法: /** * Create a new job instance....资源集合现在可以通过调用 preserveQueryParameters() 方法在 API 资源分页时保留查询字符串: return MyResourceCollection::make($repository

    1.6K20

    在 Laravel 中当 MySQL 异常宕机时强制返回空数据

    业务常规的查询逻辑如下: 从redis中获取数据, 有则返回 当第一步redis无数据, 去MySQL查询数据 把第二步查询到的数据写入redis 返回数据 问题分析 redis当然不会有问题, 问题是在第二步的时候...当MySQL宕机强制缓存空数据到redis,允许部分页面为空.而不是无法提供服务 解决思路 设置好合理的MySQL连接超时时间 mysqlnd.net_read_timeout = 3 当数据库连接超时之后..., 抛出异常 新建一个基础模型BaseModel, 其它所有模型继承这个模型, 并重写newEloquentBuilder方法 <?...try { return parent::get($columns); } catch (\Exception $e) { // 根据 laravel..., 继续抛出异常 throw $e; } } } 之后需要重点监控日志报错, 来确定页面为空是运营配置的问题还是数据库异常的问题

    14610

    2021-07-18 Laravel5.8结合MeiliSearch+Scout全文搜索

    折腾那么久之后,还是就回归misiyu了 ---- 不管怎么说,最近以来,编程能力也是有不少提高的,虽然很久没写php了,但是编程这东西很多东西真是互通的.....前言 Laravel官方已经有scout+meilisearch 的一键扩展包 见:https://packagist.org/packages/laravel/scout 但是,肯定是不支持5.8版本的...; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Facades\Log; use Laravel\Scout\Builder...---- 上面完成之后,你需要: 在模型Model.php中,增加use Searchable; 如: class Article extends Model { use Searchable;...//.... } 接下来需要做的就是将其绑定到 Scout 扩展中,我们可以通过在 AppServiceProvider 的 boot 方法中添加以下代码来实现: // 注册新的搜索引擎 resolve

    2.2K40

    Laravel源码分析之模型关联

    使用模型关联给应用开发带来的收益我认为有以下几点 主体数据和关联数据之间的关系在代码表现上更明显易懂让人一眼就能明白数据间的关系。...按照Laravel设定好的模式来写关联模型每个人都能写出高效和优雅的代码 (这点我认为适用于所有的Laravel特性)。...}); } 在定义一对多关联时返回了一个 \Illuminate\Database\Eloquent\Relations\HasMany 类的实例,Eloquent封装了一组类来处理各种关联,其中...($user->posts as $post) { // } 还记得我们上一篇文章里讲获取模型的属性时提到过的吗?...models); } return $this->related->newCollection($models); } } 关联方法 出了用动态属性加载关联数据外还可以在定义关联方法的基础上再给关联的子模型添加更多的

    9.6K10

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

    ORM 两种最常见的实现方式是 Active Record 和 Data Mapper,Active Record 尤其流行,在很多框架中都能看到它的身影,比如 Laravel 框架使用的 Eloquent...下载 Eloquent ORM 相关扩展包 Eloquent ORM 作为 Laravel 框架自带的 ORM 实现,还可以在 Laravel 框架之外作为独立的 ORM 组件使用。...Eloquent 提供的模型事件功能,还可以下载 Laravel 提供的独立事件扩展包: composer require illuminate/events 上述扩展包下载完成后,就可以在博客项目根目录下的...模型类全局可用(为了编写 Eloquent 模型类,如果只是使用 Laravel 提供的数据库查询构建器功能,则不需要这些操作)。...重构博客项目数据库操作代码 编写好模型类之后,我们来重构博客项目中之前的数据库交互代码,改为通过模型类获取: class HomeController extends Controller {

    2K10

    通过 Laravel Eloquent 模型实现简单增删改查操作

    「ActiveRecord」是 ORM 的一种实现模式,Eloquent 则是 Laravel 版的「ActiveRecord」。...实际上,Eloquent 模型类底层的查询也是基于查询构建器来实现的,你可以在模型类上调用所有查询构建器的 Where 查询方法,同样是以流接口的模式构建方法链调用即可。...因为是查询构建器,所以我们还可以在模型查询操作中对查询结果进行排序和分页: $posts = Post::where('views', '>', 0)->orderBy('id', 'desc')->offset...注:除获取单条记录之外,ELoquent 模型类查询返回的结果都是集合类,因此你可以在查询结果上调用集合类的所有方法,还可以自定义模型对应集合类,详情请查看对应官方文档。...,并将查询条件作为对应字段值设置到模型属性上。

    8K20

    Laravel 7发行说明

    如前所述,在大改之后的 Laravel7 当中这是一个非常小又普通的一个功能,而且还没有演示匿名组件,内联视图组件和各种各样的其他特性。...$post; }); 隐式绑定约束 有时,当在路由中隐式绑定多个 Eloquent 模型时,可能希望对第二个 Eloquent 模型进行约束,使其必须是第一个 Eloquent 模型的子类。...7 将自动确定查询范围,以使用约定猜测其父级上的关系名称,以其父级检索嵌套模型。...在大型应用程序(例如,具有800条或更多路由的应用程序)上,这些改进可以使简单的「Hello World」基准测试每秒的请求速度 提高2倍 ,而无需更改应用程序。...有时可能希望指定可以尝试多次的任务,但是如果重试是由给定数量的异常触发的,则该任务将失败。在Laravel7中,可以在任务类上定义 maxExceptions 属性: <?

    9K20

    【Laravel系列4.3】模型Eloquent ORM的使用(一)

    其实,Laravel 中的 Eloquent ORM 也是 Active Record 的实现,这也是现在 ORM 的主流。...在英文命名中,复数一般都会加 s 的,所以,如果是走的自动映射表名的话,会在大驼峰转换之后再加一个 s 到表名后面。 好吧,原来如此,但是这样我们就用不了这个表了?...对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...在这里比较奇怪的是,我们在实例化和赋值的过程中没有给对象的主键 id 赋值,但是在 save() 之后,id 就有值了,而且是我们新插入的数据 id ,是不是很高大上。...下篇文章我们还将继续进行模型的学习以及整个模型的源码分析。 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

    8.9K20

    Laravel学习笔记(四)——模型,更安全的数据存取

    前言 如果你是一个从没用接触过框架的新手,你在进行数据库操作的时候可能会创建数据库链接,然后进行数据操作,最后关闭数据库连接。...而在Laravel中的模型就相当于一个功能完善的数据库Helper类,不需要用户自己写,只要掌握基本用法就能很快速方便的对数据库进行操作,哪怕你一点不懂SQL语句。...看了接下来的Laravel模型的使用之后你就会爱上Laravel的Eloquent ORM模型,这也是我直接介绍模型而不讲解其他数据库操作的原因。...Laravel 数据库配置 要想使用模型,第一个要设置的当然是数据库信息。...Eloquent ORM Laravel 的 Eloquent ORM 提供了漂亮、简洁的 ActiveRecord 实现来和数据库交互。每个数据库表都有一个对应的「模型」用来与该表交互。

    1.7K00

    Laravel学习笔记(四)——模型,更安全的数据存取

    前言 如果你是一个从没用接触过框架的新手,你在进行数据库操作的时候可能会创建数据库链接,然后进行数据操作,最后关闭数据库连接。...而在Laravel中的模型就相当于一个功能完善的数据库Helper类,不需要用户自己写,只要掌握基本用法就能很快速方便的对数据库进行操作,哪怕你一点不懂SQL语句。...看了接下来的Laravel模型的使用之后你就会爱上Laravel的Eloquent ORM模型,这也是我直接介绍模型而不讲解其他数据库操作的原因。...Laravel 数据库配置 要想使用模型,第一个要设置的当然是数据库信息。...Eloquent ORM Laravel 的 Eloquent ORM 提供了漂亮、简洁的 ActiveRecord 实现来和数据库交互。每个数据库表都有一个对应的「模型」用来与该表交互。

    2.1K00

    结合 Bootstrap + Vue 组件实现 Laravel 异步分页功能

    在日常开发中,对数据库查询结果进行分页也是一个非常常见的需求,我们可以基于之前介绍的查询方法和前端 HTML 视图实现分页功能,不过从 Laravel 5.3 开始,Laravel 框架就已经为我们提供了非常完整的分页解决方案...不管你使用查询构建器还是 Eloquent 模型类,都可以在一分钟内完成分页功能,Laravel 还为我们提供了丰富的自定义支持,不管是后端的分页器,前端的分页链接,还是整个分页视图,都可以按需进行定制化开发...关于如何使用 Laravel 自带的分页功能进行分页,可以参考官方文档中的分页章节,说的非常清楚,在这篇教程中我们就不再一一演示了,不过 Laravel 自带的分页器实现的分页链接是动态 URL,不利于...在本例中,我们就用到这个特性,比如我们设置了两个模型属性 paginator 和 elements,分别用于装载接口返回分页数据和组装分页页码及对应URL数据。...通过列表渲染显示分页数据和链接 在设置好 paginator 和 elements 属性值之后,就可以在模板中通过列表渲染和动态绑定显示文章信息和分页信息了,具体可以查看 template 标签中的代码

    7.4K20

    (转) Laravel Eloquent 提示和技巧

    模型 boot() 方法 在Eloquent模型中有一个名为boot()的方法,您可以在其中覆盖默认行为: class User extends Model { public static...:updating(function ($model) { // do some logging }); } } 可能最常见的例子之一是在创建模型对象时设置一些字段值...模型属性:timestamps, appends等。 Eloquent模型有一些“参数”,以该类的属性形式出现。最受欢迎的可能是这些: ?...命令行创建模型的同时,创建迁移文件和控制器 laravel创建模型的命令大家都很熟悉: php artisan make:model Company 不过你应该了解另外几个很常用的参数: php artisan...-c 表示创建模型对应的控制器 -r 表示创建的控制器属于资源控制器 -f 表示创建模型对应的工厂文件 实际上上述几个情况,也可以通过 -a 来实现 php artisan make:model

    1.5K30
    领券