php orm 链式,关于php:雄辩的ORM中的交叉和分页

大家好,我有3张桌子:

具有以下属性的名为content的表:

id

name

table_type_id

release_date

popularity

另一个名为content_genres的表,具有以下属性:

content_id

genres_id

另一个具有以下属性的表,称为genres:

id

name

每个内容可以具有多种类型,一种类型可以具有多种内容。(许多)

好的,直到这里是不同表的定义,现在我正在尝试进行查询以搜索具有genre_id = 1和同时genre_id = 2的内容

在postgresql中,这很容易:

SELECT content.id

FROM content INNER JOIN content_genres ON content.id =content_genres.content_id

WHERE content_genres.`genres_id`= 1

INTERSECT

SELECT content.id

FROM content INNER JOIN content_genres ON content.id =content_genres.content_id

WHERE content_genres.`genres_id`= 2

;

我进行一个查询,再进行另一个查询,然后进行交集以获取具有genre_id 1和2的内容

但是当我试图雄辩地编写相同的查询时,我遇到了一些问题:

查询1:

$content1=$this->content::join('content_genres','content_genres.content_id','=','content.id')

->with('genres')

->where('content_genres.genres_id',1)

->where('content.table_type_id',1)

//->whereYear('release_date',2017)

->select('content.id','content.name','content.popularity')

->orderBy('popularity','desc')->get();

查询2:

$content2=$this->content::join('content_genres','content_genres.content_id','=','content.id')

->with('genres')

->where('content_genres.genres_id',2)

->where('content.table_type_id',1)

//->whereYear('release_date',2017)

->select('content.id','content.name','content.popularity')

->orderBy('popularity','desc')->get();

路口:

$final_result=$content1->intersect($content2);

好的,我们以这种方式看到的图像能够交叉,但我有一些问题:

当我想进行手动分页时,我不知道如何计算将要有交点的元素,然后限制交点的结果。

例:

查询1的结果数:

18950

查询2的结果数:

22650

相交的结果数

3457

这非常慢,因为我不能说将查询1限制为100个结果,将查询2限制为100个结果,然后进行相交,所以我不能这样做,因为相交的结果数不会总是相同,因此出于这个原因,我如何在不加载query1和query2的所有结果的情况下,对交点进行手动分页,说我想对20个结果中的交点进行分页?

最后一件事是我整周都遇到的大问题。

真实的例子

您转到此页面,然后在年份中不输入任何内容,在类型中选择两个随机类型。您如何看到该交叉点的分页始终为20,这并不取决于交叉点是否有更多结果,或者始终没有,这始终是20。而且我很确定它们没有从db中全部加载结果。

好结果:

多亏了答案,正确的方法如下:

$this->content::join('content_genres as g1','g1.content_id','=','content.id')

->join('content_genres as g2','g2.content_id','=','content.id')

->where('g1.genres_id', 1)

->where('g2.genres_id', 2)

它对我有用,我可以选择其他选项,但是我有很多对很多的关系,因为我的content_genres是数据透视表,但是我认为我也是有效的。

您应该合并两个查询。 我看到了两种方法。

1)两次加入content_genres:

$this->content::join('content_genres as g1','g1.content_id','=','content.id')

->join('content_genres as g2','g2.content_id','=','content.id')

->where('g1.genres_id', 1)

->where('g2.genres_id', 2)

2)使用whereHas():

$this->content::whereHas('content_genres', function($query) {

$query->where('genres_id', 1)

})->whereHas('content_genres', function($query) {

$query->where('genres_id', 2)

})

这需要一个关系:content→HasMany→content_genres

谢谢,它有效。但是我有一个问题,两个联接有效吗? 因为也许两个联接都是可竞争的,但是如果用户选择过滤大约3或4种类型,那么在性能方面会发生什么? 我可以进行循环并随时加入所需的时间,但是我不知道,这是有效的选择吗?

联接应该比子查询更有效(stackoverflow.com/q/13063772/4848587)。 我认为,如果添加必要的索引,那么一些联接不应该成为性能问题。 确保使用EXPLAIN分析您的查询。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/508093.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2019java形势,2019Java开发还有哪些发展

相信已经有不少人在心里考虑着春节之后转行新工作了吧,而在众多行业中IT行业,特别是Java开发、Java程序员等岗位相信是很多人的首选。谁让现在程序员薪资这么高呢,但是现在互联网发展迅速,各类编程语言层出不穷,比如py…

php取消转译代码,PHP在我不需要的时候进行转义

我有一个问题,即PHP在我不希望它出现在代码中的地方进行转义:$url_ stripslashes(((substr(strtolower($url),0,7)!"http://")? "http://".$url:$url));$host $this->googleDomains[mt_rand(0,count($this->googleDomains)-1)];$target "/s…

matlab给plc发送命令,想学习下如何将PLC发送的指令让软件接收到?

PLC作为下位机,接收上位机的执行命令,并将执行结果反馈给上位机。工具/原料电脑、PLC、USB转RS232数据线和RS232转RS485模块(或者USB转RS485)方法/步骤PLC与电脑线路连接,根据电脑的串口情况,1.电脑自带RS232串口,那么…

mysql允许两个用户远程连接,配置MySQL服务允许用户远程连接

默认情况下,mysql只允许本地登录,如果要开启远程连接,则需要修改/etc/mysql/my.conf文件。一、修改/etc/mysql/my.conf找到bind-address 127.0.0.1这一行改为bind-address 0.0.0.0即可二、为需要远程登录的用户赋予权限1、新建用户远程连接…

pupload 文件分块 php,基于Plupload实现Base64分割的文件上传方案

标题:基于Plupload实现Base64分割的文件上传方案关键词:文件上传、Base64、Plupload、Blob、分割上传领域:Web前端作者:孙振强日期:2018-04-13目录背景存在问题2.1. 体积增加1/32.2. 大文件上传不稳定方案思路3.1. 将服…

php imagick手册,PHP中使用Imagick实现各种图片效果实例

这篇文章主要介绍了PHP中使用Imagick实现各种图片效果实例,本文讲解了偏置图像、改变图片大imagick是一个功能强大的图像处理库。说是翻译 其实就是简要介绍imagick 的主要功能的或者说是我觉得比较实用的功能函数的介绍 以及使用的例子。因为本人的英语水平有限,所…

php流程控制的类型有哪些,流程控制包括哪些内容

流程控制也称为控制流程,是计算机运算领域的用语,其内容包括在程序运行时,个别的指令或是陈述、子程序运行或求值的顺序,不论是在声明式编程语言或是函数编程语言中,都有类似的概念。控制流程(也称为流程控制)是计算机…

PHP公鸡五文钱,公鸡

中国古代数学家张丘建在他的《算经》中提出了一个著名的“百钱买百鸡问题”,鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁、母、雏各几何?实现过程&#…

oracle11g创建闪回分区多大,Oracle闪回区大小预估

一个朋友问如何设置Oracle闪回区大小,有什么依据没有。查证官方文档,有如下描述For example, if you intend to setDB_FLASHBACK_RETENTION_TARGET to 24 hours, and if the database generates 20 GB of redo in a day, then a rule of thumb is to all…

平方变换法提取载波MATLAB,毕业设计(论文)MPSK信号的载波同步算法研究与仿真.doc...

目录摘要IAbstractII第一章 绪论1相移键控技术1第二章 载波同步原理22.1平方变换法和平方环法22.2 同相正交3第三章 相移键控(PSK)信号的调制原理63.1 二进制相移键控的基本原理63.2 二进制差分相移键控(DPSK)的基本原理83.3 多进制相移键控(MPSK)的基本原理113.3.1 QPSK调制原…

oracle dba_waiters中的lockid是什么,查杀oracle lock session and table

查杀oracle 死锁的一些帖子摘录[more]查找死锁进程column sid format 999;column b format 9;column object_name format a30;select v$lock.sid,decode(v$lock.type,MR, Media Recovery,RT,Redo Thread,UN,User Name,TX, Transaction,TM, DML,UL, PL/SQL User Lock,DX, Distri…

查询linux服务器事物传输失败日志,查看fail2ban日志代替lastb查看登录失败记录

之前我曾经用shell脚本提取lastb登录失败超过指定次数的IP加入到iptables,来禁止这些IP登录主机,达到防止恶意攻击的目的。后来为了给主机提供更全面的防护,又安装了fail2ban。今天早上我收到fail2ban发过来的报警邮件提示我禁止了一个IP登录…

文件字符串变量插入linux,Linux Shell脚本实现在文件指定的行插入字符串

涉及知识点:grep字符串查找,awk截取列,until条件操作,sed字符串插入,变量与字符串连接等。人工操作(首先vim打开文件找到字符串所在的位置,插入操作):vim /etc/glance/glance-api-paste.ini# Li…

linux系统子接口配置文件,Linux网卡绑定、子接口-IP别名

查看网卡线缆状态:mii-tool eth0查看网卡底层信息:ethtool eth0ethtool -i eth0 查看网卡驱动信息ethtool -S eth0 查看网卡状态统计信息Linux下可以通过IP别名(子接口)功能为一个物理网卡添加多个IP地址要使用IP别名(子接口)需要关闭NetworkManager服…

linux防火墙允许dns服务,Linux防火墙设置-DNS服务器篇

亲测可用,对于刚刚搭建了DNS服务器,需要开启防火墙但又不知道该怎么设置的朋友,可以参考下面的内容,或者直接使用我下面给出的脚本程序。如果服务器是作为DNS服务器使用的,针对绝大多数的情况,为了开启防火…

发布react项目到linux服务器,nginx上部署react项目的实例方法

测试项目:react-demo克隆你的react-demo项目到服务器上(默认使用Github管理我们的项目)如果需要,请安装项目环境,比如:node.js,yarn等进入项目目录,执行npm run build,开始构建项目构建成功之后…

linux取消线程的原理,浅析 Linux 进程与线程

简介进程与线程是所有的程序员都熟知的概念,简单来说进程是一个执行中的程序,而线程是进程中的一条执行路径。进程是操作系统中基本的抽象概念,本文介绍 Linux 中进程和线程的用法以及原理,包括创建、消亡等。进程创建与执行Linux…

linux查看注册表信息,linux下登录档及其查看方法

一、Linux 常见的登录档档名登录档可以帮助我们瞭解很多系统重要的事件,包括登入者的部分资讯,因此登录档的权限通常是设定为仅有 root 能够读取而已。 而由于登录档可以记载系统这麽多的详细资讯,所以啦,一个有经验的主机管理员会…

Linux系统openssl升级,在Linux系统上升级OpenSSL的方法

我是用的centos ,目前官方说受威胁的版本是1.0.1f, 1.0.1e, 1.0.1d, 1.0.1c, 1.0.1b, 1.0.1a, 1.0.1 。在openssl 1.0.1g版本中“ heartbleed”漏洞被修复。所有centos6.5的系统运行openssl 1.0.1e (openssl-1.0.1e-16.el6_5.4) 都会受到威胁,貌似只有6.…