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

解决laravel查询构造器中的别名问题

Laravel框架对数据库的封装是比较完善的,用起来也比较方便。但之前有一个问题一直困扰着我,就是利用laravel查询时。如果想给表名或是字段名起别名是比较麻烦的事。...加别名的写法:DB::table(‘users as table1’)- select(‘id’)- get(); 这样写也不会产生错误 我们尝试另一咱写法:DB::table(‘users as table1...’)- select(‘table1.id’)- get(); 这样写就报错了,但这种写法我们又是不能避免的,如我们要表users表进行自连接时,就必须要用到别名加点的方式去得到字段。...`id` from `ykttb_users` as `table1` 我们发现写table1.id时,laravel框架自动给我们加上了表前缀,很显然,这样的SQL语句得不到我们要的结果。...总结:在laravel中,给表起别名,直接写就可以;但在select语句中要用到表的别名来得到字段,我们就要在外面套一层DB::raw()。

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

Laravel拼装SQL查询的最佳实现

比如查询一个product表,要求查询条件中,product_catagory 表的某些字段存在才能才回。 写多了容易无解,直接上SQL: ?...大家注意那个 IN 子句,其实是一个查询结果集,从另个表返回的。 写SQL真的很伤神,不如用框架自带的orm,操作起来非常人性化,拼装也很简单。那就抛出一个问题,Laravel如何实现上述的查询?...对Laravel来说,简直不要太简单,你只要在写whereIn的时候,将数组使用闭包返回就可以了。...写在最后 本文通过一个SQL语句查询Laravel中的实现方式,解释了laravel在拼装SQL查询时的自由度,使用起来非常灵活。...对于固定的查询方式,或者经过优化的SQL语句,你大可直接发送给Laravel直接运行以便提高效率。

3.6K10

Laravel框架关键技术解析

结束这个区块,则视图文件将无法覆盖这个区块 @parent:用于显示继承的布局模板中的内容 @yield(‘区块文件’,'默认内容’):用于在布局文件中定义一个区块,默认内容不是必须的 @include(‘视图名称...’):用于在视图文件中加载视图文件,使得视图文件结构清晰 六、Laravel框架中的设计模式 A.服务容器 1.将服务理解为系统运行中需要的东西,如对象、文件路径、系统配置等,服务容器就是这些东西的载体...4.两个别名:一是容器核心别名,存在Application中的$aliases,另一个是外观别名,定义在app.php配置文件中,程序运行后存储在AliasLoader类实例的$aliases属性中 5...down-autoload一下 php artisan db:seed [—class=类名] B.查询构造器 1.Laravel框架的查询构造器是在PDO扩展基础上设计的一个“重量级”的数据库扩展...(\Illuminate\Database\Query\Builder)实例封装了数据库连接实例、请求语法实例和结果处理实例,这里类的实例提供了统一的接口方法供查询构造器实例使用 5.查询构造器使用阶段

11.9K20

Laravel基础

$name; })->where['id'=>[0-9]+,'name'=>[A-Za-z]+] 2.1.5 路由别名 Route::get('user/member-center',['as' =>..., ['abcd']); laraevl内置函数dd,可人性化的打印数组:dd($result); 3.2 数据库操作 - 查询构造器 3.2.1 查询构造器简介 Laravel 查询构造器(query...['aa', 'bb']; //不允许批量赋值的字段 黑名单设置 $fillabel 是为了防止注入攻击,比如有的用户可能在表单中注入了一些别的信息更改数据库中的其他内容,因此我们要定义哪些数据是被修改的...i:s', time()) }} 模板中强制输出 @{{ $name }} 字符串 @{{ $name }} 模板注释格,不会在查看源代码中显示,和html注释的区别 {{-- 模板注释 --}} 视图引用...url route() 参考视频教程:轻松学会Laravel-基础篇

7.7K30

深入剖析 Laravel 服务容器

注册基础服务提供者 注册核心服务别名到容器 管理所需创建的类及其依赖 bind 方法执行原理 make 解析处理 资料 序章 如果您有阅读我的前作 深度挖掘 Laravel 生命周期 一文,你应该已经注意到...一以蔽之:面向接口编程。 至于如何实现面向接口编程,在 依赖注入系列教程 的前两篇中有实例演示,感兴趣的朋友可以去阅读这个教程。...() 将具体的「依赖注入容器」及其别名注册到「Laravel 服务容器」。...注册核心服务别名到容器 用过 Laravel 框架的朋友应该知道在 Laravel 中有个别名系统。...Facades 和别名系统我们可以很方便的通过别名来使用 Laravel 内置提供的各种服务。

8.9K10

Laravel Facades的实现原理

Facades 什么是Facades Facades是我们在Laravel应用开发中使用频率很高的一个组件,叫组件不太合适,其实它们是一组静态类接口或者说代理,让开发者简单的访问绑定到服务容器里的各种服务...Laravel文档中对Facades的解释如下: Facades 为应用程序的 服务容器 中可用的类提供了一个「静态」接口。...Laravel 本身附带许多的 facades,甚至你可能在不知情的状况下已经在使用他们!...下面我们会大概看一下Facades从被注册进Laravel框架到被应用程序使用这中间的流程。...,比如当我们使用别名类 Route时PHP会通过AliasLoader的load方法为 Illuminate\Support\Facades\Route类创建一个别名类 Route,所以我们在程序里使用别

1.1K20

Laravel框架的核心架构,你懂多少?

首先应该了解laravel框架的架构模式(设计核心,laravel 框架是使用服务组件化的开发模式开发的,laravel框架就是由不同的服务组件构成的) laravel 里面多个服务提供者构成了laravel...IlluminateCacheCacheServiceProvider::class,提供缓存服务的服务提供者 好处:开发者可以节省下更多的精力去处理项目逻辑,且不同开发个体之间达到一定默契,最重要的是...3 config/app.php中服务别名alias大多数都使用了facade 4 使用facade是有风险的,并不是用的越多越好,这在手册上有少量的介绍,但具体的,还是需要开发中去发现 laravel...IlluminateCookieCookieServiceProvider::class, IlluminateDatabaseDatabaseServiceProvider::class, 所以又引出了别名...,使用别名之后 简化了我们调用的服务提供者的类。

2.8K20

Laravel框架的核心架构,你懂多少?

首先应该了解laravel框架的架构模式(设计核心,laravel 框架是使用服务组件化的开发模式开发的,laravel框架就是由不同的服务组件构成的) laravel 里面多个服务提供者构成了laravel...IlluminateCacheCacheServiceProvider::class,提供缓存服务的服务提供者 好处:开发者可以节省下更多的精力去处理项目逻辑,且不同开发个体之间达到一定默契,最重要的是...3 config/app.php中服务别名alias大多数都使用了facade 4 使用facade是有风险的,并不是用的越多越好,这在手册上有少量的介绍,但具体的,还是需要开发中去发现 laravel...IlluminateCookieCookieServiceProvider::class, IlluminateDatabaseDatabaseServiceProvider::class, 所以又引出了别名...,使用别名之后 简化了我们调用的服务提供者的类。

2.9K10

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

在上一篇教程中,我们通过查询构建器实现了简单的增删改查操作,而日常开发中,往往会涉及到一些更复杂的查询语句,比如连接查询查询、排序、分页、聚合查询等等,这一篇教程我们将围绕这些内容展开探讨。...查询小技巧 我们首先来介绍几个 Laravel 自带的语法糖,可以帮助我们快速获取期望的查询结果,提高编码效率。...查询 有时候,我们会通过查询关联不同的表进行查询,考虑下面这个 SQL 语句: select * from posts where user_id in (select id from users...,普通的 WHERE 查询也可以使用查询,对应的方法是 whereSub,但是查询的效率不如连接查询高,所以我们下面来探讨连接查询查询构建器中的使用。...取个别名:select('posts.*', 'users.name as username', 'users.email')。

29.8K20

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

Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的、易于使用的、基于数据库结果集的分页。分页器生成的 HTML 兼容 Bootstrap CSS 框架。...默认情况下,当前页通过 HTTP 请求查询字符串参数 page 的值判断。当然,该值由 Laravel 自动检测,然后自动插入分页器生成的链接中。...包含视图 被包含的视图可以引用父视图定义的所有变量。...你可以传递额外的数据到视图 定义父视图 parent.blade.php,并包含视图 child.blade.php,且传入额外数据 <!...-- 包含视图 -- @include("child" , [ "other" = "额外数据" ]) 总结 到此这篇关于laravel中blade模板带条件分页的文章就介绍到这了,更多相关laravel

7.2K30

Laravel神奇的服务容器

Laravel的核心是IocContainer, 文档中称其为“服务容器”,服务容器是一个用于管理类依赖和执行依赖注入的强大工具,Laravel中的功能模块比如 Route、Eloquent ORM、Request...concrete, true); } singleton 方法是bind方法的变种,绑定一个只需要解析一次的类或接口到容器,然后接下来对于容器的调用该服务将会返回同一个实例 alias 把服务和服务别名注册到容器...$alias) { $this->aliases[$alias] = $this->normalize($abstract); } alias 方法在上面讲bind方法里有用到过,它会把把服务别名和服务类的对应关系注册到服务容器的...服务解析 服务解析是从服务容器中解析出在服务绑定过程中注册到服务容器里的对象,我们过很方便的通过make方法来解析出服务对象,通过如果服务对象如果有依赖其他类对象的话服务容器也会帮助我们依次解决依赖从而免去了在程序里使用服务对象前先要在代码里实力化一堆依赖对象的繁重操作...你可以点击“阅读原文”查看Laravel服务容器详细的源码解析,希望看完后能解决你在使用过程中的一些疑惑。

1.5K30

php中Laravel之Blade模板引擎

Blade是Laravel提供的一个既简单又强大的模板引擎,Blade允许在视图中使用原生php代码,所有Blade视图页面都将被编译成原生php代码并缓存起来,除非你的模板文件被修改了,否则不会重新编译...{undefined{-- 模板中的注释 --}} 发现这个注释查看源里不显示  (5)引入视图include 在student目录下新建一个common视图,写:我是include....然后在section1视图里写:@include('student.common') @include(‘目录名/视图名’) 当然也可以向视图传值: 在common视图里写:我是include{...url()  路由的方式(这个最简单) action()  控制器名+方法名 route()   路由别名的方式 具体操作:  在student控制器里新增一个test5方法,用来测试 public function...}}"> action() 点击跳转到test5里(控制器名@方法名方式 route()点击跳转到test5里( 路由别名方式

1.8K20

Laravel系列4.2】查询构造器

查询构造器 什么是查询构造器?...其实,查询构造器就相当于我们将原始 SQL 的操作进行了一次封装而已。而且,在模型中,其实内部调用的也是这个 查询构造器 。也就是说,查询构造器是介于 模型 和 原始语句 操作中间的一层。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...// array:1 [ // 0 => 10 // ] 感觉很复杂吧,日常开发中我们很少会写这样的复杂的连查语句,这里只是让大家知道这些功能要实现都不是问题,如果真的有需要的场景,想起来可以这么用就行了..., $this->getPostProcessor() ); } 注意这个 QueryBuilder 实际上是 use Illuminate\Database\Query\Builder 的别名

16.8K10
领券