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

3分钟短文 | Laravel 日志全程记录 SQL 查询语句,要改写底层?

我们使用全局的 Config 类获取配置信息: Config::get('database.log', false) 如果没有开启数据库日志,则手动处理,将上述 illuminate.query 事件的监听器写入系统内...当然传入的参数要多一些, query, bindings, time, name,分别是 SQL 语句,绑定的参数,执行的时间,以及标志名。...为了处理方便,将所有原始数据写入 Log 类方法的第二个传参, 我们将参数打包到数组: $data = compact('bindings', 'time', 'name'); 因为单个SQL语句绑定的参数有很多...我们需要做的工作,就是把位置参数和SQL语句进行还原,生成原始的带参数的SQL语句, 不得不提 vsprintf 这个函数,大家有必要深入学习一下。..., array('%%', '%s'), $query); $query = vsprintf($query, $bindings); 注意laravel生成的SQL语句占位符是问号,而vsprintf

1.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    laravel 学习之路 数据库操作 查询数据

    运行 Select 查询 你可以使用 DB Facade 的 select 方法来运行基础的查询语句我们在上面创建的路由里增加个 index 的路由 dump 是 laravel 的打印函数可以把它理解为...传递给 select 方法的第一个参数就是一个原生的 SQL 查询,而第二个参数则是需要绑定到查询中的参数值。通常,这些值用于约束 where 语句。参数绑定用于防止 SQL 注入。...使用命名绑定 除了使用 ?...它可用于执行应用程序中大部分数据库操作,且可在所有支持的数据库系统上运行。 Laravel 的查询构造器使用 PDO参数绑定来保护您的应用程序免受 SQL 注入攻击。...因此没有必要清理作为绑定传递的字符串 注意:PDO 不支持绑定列名。因此,不能让用户通过输入来指定查询语句所引用的列名,包括 order by 字段等等。

    3.2K20

    深入剖析 Laravel 服务容器

    Laravel 服务容器的使用方法 Laravel 服务容器在使用时一般分为两个阶段:使用之前进行绑定(bind)完成将实现绑定到接口;使用时对通过接口解析(make)出服务。...Laravel 内置多种不同的绑定方法以用于不同的使用场景。但无论哪种绑定方式,它们的最终目标是一致的:绑定接口到实现。...在讲解这些绑定方法前,先讲一个 Laravel 服务容器的使用场景。 管理待创建类的依赖 通过向服务容器中绑定需要创建的类及其依赖,当需要使用这个类时直接从服务容器中解析出这个类的实例。...实例绑定的功能是将已经创建的实例对象绑定到接口以供后续使用,这种使用场景类似于 注册表。...得益于 Laravel Facades 和别名系统我们可以很方便的通过别名来使用 Laravel 内置提供的各种服务。

    9K10

    laravel与thinkphp之间的区别与优缺点

    Laravel框架: Laravel是当今最熟练,流行和广泛使用的开源框架之一,一直秉承着优雅的原则,完美支持**composer**,实现了更丰富的扩展,社区文档活跃,相较于TP,Lavavel更庞大...3、Laravel框架提供了大量的闭包 作为菜鸟的我目前只使用了use方法,即如何在函数内部使用外层变量。...5、条件判断语句书写方式的差异 Laravel框架里if else判断语句和foreach语句,书写时必须以@if开头,以@endif结尾。...如果没有则报语法错误,@foreach @endforeach同理;而TP框架则和PHP语法规则使用方式一致,直接用if esle语句判断和foreach循环遍历。...8、建表 Laravel在数据库建表上有自己独立内置的结构,可以完全不用借助原生SQL语句或者SQLyogEnt、Navicat这样的建表工具进行数据库的建立,增删改查和数据交互。

    5.7K20

    Laravel源码笔记(二)路由

    我们在实际开发过程中,往往根据需求不同会隔离用户的使用场景,典型的例子就是CMS程序的管理端和用户端。...因为对于开发者来说,route文件的配置其实是很少改动的,因此laravel在这里使用了静态文件缓存将解析好的路由规则缓存起来,缓存路径为/bootstrap/cache/routes.php。...laravel 首先对路由进行正则编译,得到路由的正则匹配串regex,然后利用请求的参数url尝试去匹配,如果匹配成功,那么就会选定该路由: class Route { public function...首先,拼接出的regex采用了子命名组语法,即(?P表达式)的形式。这里是为了后面与请求url进行参数绑定的时候方便取出变量名和变量值。.../tai l$#s 3.3 参数绑定         得到一个路由的正则表达式regex之后,laravel就可以后续处理请求的时候使用它了:一是用来匹配url,二是用来获取url参数。

    7.5K40

    Laravel5.3之Container源码解析

    说明:本文主要学习Laravel中Container的源码,主要学习Container的绑定和解析过程,和解析过程中的依赖解决。分享自己的研究心得,希望对别人有所帮助。...实际上Container的绑定主要有三种方式:bind(),singleton(),instance(),且singleton()只是一种'shared' = true的bind(),这些已经在Laravel5.3...开发环境: Laravel5.3 + PHP7 + OS X 10.11 PHPUnit测试下绑定 在聊解析过程前,先测试下\Illuminate\Container\Container中绑定的源码,这里测试下...,绑定接口和对应实现,依赖解析这三个feature,singleton()测试了是否为单例绑定一个feature,instance()测试了已存在对象绑定这个feature,测试结果5个tests都通过...class,而这个依赖又有自己的依赖IContainerStub::class,从断言语句this->assertInstanceOf(ContainerImplementationStub::class

    4.4K51

    Laravel5.3之Container源码解析

    说明:本文主要学习Laravel中Container的源码,主要学习Container的绑定和解析过程,和解析过程中的依赖解决。分享自己的研究心得,希望对别人有所帮助。...实际上Container的绑定主要有三种方式:bind(),singleton(),instance(),且singleton()只是一种'shared' = true的bind(),这些已经在Laravel...开发环境: Laravel5.3 + PHP7 + OS X 10.11 PHPUnit测试下绑定 在聊解析过程前,先测试下\Illuminate\Container\Container中绑定的源码,这里测试下...,绑定接口和对应实现,依赖解析这三个feature,singleton()测试了是否为单例绑定一个feature,instance()测试了已存在对象绑定这个feature,测试结果5个tests都通过...关于在PHPStorm中配置PHPUnit可参考这篇:Laravel学习笔记之基于PHPStorm编辑器的Laravel开发 make()源码解析 从以上testcase知道,make()是负责从Container

    1.4K21

    Laravel和Thinkphp有什么区别,哪个框架好用

    Laravel和Thinkphp这两个php框架对于php程序员都不陌生,新手可能对Thinkphp比较熟,也是国内比较出名的开源框架,更高级的Laravel一般有点经验的才使用。...3、Laravel框架提供了大量的闭包 作为菜鸟的我目前只使用了use方法,即如何在函数内部使用外层变量。...5、条件判断语句书写方式的差异 Laravel框架里if else判断语句和foreach语句,书写时必须以@if开头,以@endif结尾。...如果没有则报语法错误,@foreach @endforeach同理;而TP框架则和PHP语法规则使用方式一致,直接用if esle语句判断和foreach循环遍历。...本人在实际使用中也实实在在的感受到了通过创造模型对数据表操作带来的便利,譬如:批量赋值,跨表查询,删除模型和软删除,模型关联,当然这些在TP框架中也可以利用模型实现。

    6.1K20

    深入剖析 Laravel 服务提供者实现原理

    Laravel 如何完成延迟加载类型的服务提供者 总结 服务提供者基本概念 我们知道 「服务提供者」是配置应用的中心,它的主要工作是使用「服务容器」实现服务容器绑定、事件监听器、中间件,甚至是路由的注册...服务提供者的典型处理流程是,当接 Laravel 应用接收到 HTTP 请求时会去执行「服务提供者的 register(注册)」方法,将各个服务「绑定」到容器内;之后,到了实际处理请求阶段,依据使用情况按需加载所需服务...我们可以从 文档 中得到解答: 如果你的服务提供商注册许多简单的绑定,你可能想使用 bindings 和 singletons 属性而不是手动注册每个容器绑定。 使用的服务提供者很明显,无需每次注册和启动,直到需要用到它的时候。...Laravel 如何完成延迟加载类型的服务提供者 对于延迟加载类型的服务提供者,我们要到使用时才会去执行它们内部的 register 和 boot 方法。

    4.5K10

    深度挖掘 Laravel 生命周期

    这篇文章我们来聊聊 「Laravel 生命周期」 这个主题。虽然网络上已经有很多关于这个主题的探讨,但这个主题依然值得我们去研究和学习。...下面是 bootstrap/app.php 的代码,包含两个主要部分「创建应用实例」和「绑定内核至 APP 服务容器」: 和 「引导程序」如何被使用的,会在后面的章节讲解。...2.3.1 解析内核实例 在第二阶段我们已经将 HTTP 内核 和 Console 内核 绑定到了 APP 容器,使用时通过 APP 容器 的 make() 方法将内核解析出来,解析的过程就是内核实例化的过程...还记得我们讲解「2.2 创建 Laravel 应用实例」章节的时候有「注册应用的基础路径并将路径绑定到 APP 容器」。

    7.4K20

    最棒的 7 个 Laravel admin 后台管理系统推荐 - 卡拉云

    Laravel admin 后台管理系按类型选择 选择 Laravel admin 后台管理系统之前,我用了市面上大多数 Laravel admin ,它们看起来差别不大,其实用途和使用场景差别很大。...就是自动将 CRUD 逻辑和 UI 添加到现有模型的视图和控制器集。...Nova 前端采用 Vue + Vue Route ,国内 Vue 用顺手的开发者来说 Nove 更加灵活。 Nova 没有免费试用版,小项目 99 刀授权,大项目 199 刀授权。...虽然它在性能优化上无法和官方的 Nova admin 所匹敌,但毕竟是开源项目,国内使用者众多,也有自己的开发者生态。...当然,付费的就是付费的,Backpack 文档优秀,有视频教程,非常多的前端主题可选,另外非商业项目可以免费使用,不过只要你开始用它的工具和附加选项,马上就进入付费区间了,摊手。

    10.2K02

    跟我一起学Laravel-数据库操作和查询构造器

    Ordering, Grouping, Limit, & Offset 插入操作 使用sql语句执行插入 基本插入操作 更新操作 使用sql语句执行更新操作 基本更新操作 指定列的增减 删除操作...使用sql执行删除 基本删除操作 悲观锁 事务处理 查看日志记录 其它操作 在Laravel中执行数据库操作有两种方式,一种是使用\DB外观对象的静态方法直接执行sql查询,另外一种是使用Model类的静态方法...MySQL 5.7和Postgres数据库中提供了新的数据类型json,对json提供了原生的支持,使用->可以对json列进行查询。...,或者是跳过指定行数的结果(OFFSET),可以使用skip和take方法 $users = DB::table('users')->skip(10)->take(5)->get(); 插入操作 使用sql...悲观锁 使用sharedLock方法可以避免选定的行在事务提交之前被修改 DB::table('users')->where('votes', '>', 100)->sharedLock()->get

    6.3K30

    Laravel5.3之bootstrap源码解析

    说明:Laravel在把Request通过管道Pipeline送入中间件Middleware和路由Router之前,还做了程序的启动Bootstrap工作,本文主要学习相关源码,看看Laravel启动程序做了哪些具体工作...Laravel在入口index.php时先加载Composer加载器:Laravel5.2之Composer自动加载,然后进行Application的实例化:Laravel5.3之IoC Container...关于使用第三方服务Sentry来做异常报告以后详聊,我司每天都在用这样的效率神器,很好用,值得推荐下。 5....这个过程主要使用了两个技术:一个是外观类的别名;一个是PHP的重载,可看这篇:Laravel5.2之PHP重载(overloading)。 6....service provider中,把不是defer的service provider中绑定的服务启动起来,是defer的service provider等到需要里面绑定的服务时再执行绑定。

    7K51

    Laravel的基本数据库操作部分

    [laravel] laravel的数据库配置 找到程序目录结构下.env文件 配置基本的数据库连接信息 DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=blog...DB_USERNAME=root DB_PASSWORD=root 修改完.env文件需要重启服务 [laravel] laravel的数据库入门 控制器中导入DB数据库操作类,use DB 使用DB类的静态方法...select来查询数据库,DB::select(),参数:sql语句,参数值数组 例如:$user=DB::select("select * from article where id=?"...get()方法,得到数组数据 例如:$users=DB::table("article")->get(); 查询构造器是链式调用的,还有其他方法,可以去查看文档 [laravel] 数据库的迁移 使用Artisan...[laravel] Eloquent模型 使用Eloquent模型为表建立映射模型ORM,使用Artisan命令 make:model 模型名称 例如:php artisan make:model User

    1.4K30

    3分钟短文:Laravel slug,让你的url地址更“好记”

    我们在之前的章节已经使用laravel Route功能,重新构造了url,所以访问起来像是连贯的: http://example.com/events/42 直接使用位置参数绑定的方式传递。...如果使用如下方式,效果要友好的多: http://example.com/events/laravel-hacking-and-coffee 这种基于字符串位置参数绑定的URL方式,被称为 slug。...使用 tinker 快捷操作: namespace App; $events = Event::all(); foreach($events as $event) { $event->save(...foreach循环直接用了。 创建基于 slug 的模型查询 数据库准备好了,模型准备好了,现在让我们把slug功能用起来。...当然了,如果没有使用路由参数绑定,eloquent-sluggable类库也为我们提供了友好的trait,在模型文件内直接引入就好了: use Cviebrock\EloquentSluggable\Sluggable

    3.5K11

    Laravel服务提供器

    你的应用程序自定义的服务、第三方资源包提供的服务以及 Laravel 的所有核心服务都是通过服务提供器进行注册(register)和引导(boot)的。...中, 为BroadcastingFactory的类名绑定了类实现BroadcastManager,这样就能通过服务容器来make出通过BroadcastingFactory::class绑定的服务BroadcastManger...对象供应用程序使用了。...首先laravel注册和引导应用需要的服务是发生在寻找路由处理客户端请求之前的Bootstrap阶段的,在框架的入口文件里我们可以看到,框架在实例化了Application对象后从服务容器中解析出了HTTP...如果我们想使用服务容器解析自己定义或者第三方软件包的服务就需要通过服务提供器里使用服务容器的singleton、bind、alias方法注册到服务容器中去,这样才能用服务容器make解析出服务或者时直接用门面来访问服务里提供的方法

    85040
    领券