文章详情页
mysql - laravel 子查询的问题
浏览:58日期:2022-06-15 13:33:47
问题描述
要拼成如下语句:
select field1,field2,field3 from table1 inner join (select id from table1 where field4=$field4 limit 100, 20) as temp using(id)
laravel 改怎么写?···尝试了许多都不行
感谢~
问题解答
回答1:直接用Laravel的ORM是无法实现的,至少是目前无法实现,所以这种需求还是乖乖用DB类提供的原生SQL方式吧,比如用DB::select等。
也可以参考一下这个Laravel 5. Using the USING operator,跟你一样的需求。
这里有一个pull请求,为Laravel添加对using的支持,不过貌似因为没有添加相应的单元测试被拒了。
回答2:$courses = Orgcourse::where(’classify’,’=’,$num)->join(’collections’,’orgcourses.id’,’=’,’collections.cid’)->select(DB::raw(’*,orgcourses.id as o_id,collections.id as c_id’))->orderBy(’collections.created_at’,’desc’)->paginate(2);类似于这种,能查出来,但是有点繁琐好像,关联查询
上一条:mysql - 安装gem报错下一条:mysql查询语句执行顺序
相关文章:
1. python - 通过电影名称获取视频地址2. javascript - mongoose在百度bae长连接中遇到的问题3. angular.js - jade模板引擎无法做单页模式,请教怎么做。4. javascript - swiper轮播图使用左右布局高度不一致5. (横竖屏切换/强制横屏)CSS3 transform 怎样才能中心旋转?6. javascript - vue组件中使用百度分享初次加载失败?7. javascript - 关于js中嵌套的对象的名称是变量的问题8. 如何更新/删除指定的两条或多条数据9. 为什么php修改数据无法同步到数据库,只是当前页面修改成功?10. css - font-face引入的新字体无法在火狐浏览器上显示?但是谷歌可以?
排行榜
