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

关于ThinkPHP5.1+的Log无法记录SQL调试记录的小经历

之前我的大部分项目都是使用ThinkPHP5.0以及ThinkPHP3.2,对于框架提供的日志记录和日志配置都差不多,然后使用ThinkPHP5.1的时候就吃瘪,花了十几分钟才好,所以写一下防止后面忘记了再踩坑...日志配置ThinkPHP5.1没有了config.php,日志配置单独提出来自成一块,叫Log.php,这个适应一下就可以。...日志记录在5.1以前的项目中记录个人调试的日志,都是使用use think\Log; 然后使用Log::write()。...然后5.1的时候引入了facede,所以直接用以前的方式,不能使用静态调用write等方法,修改为use think\facede\Log,然后再使用。...但是有时不会出现,但是想调试SQL以及SQL的查询速度,就需要开启日志记录,尽量不要配置保存目录,默认在runtime下就可以,也不是因为自定义目录的写入权限问题,所以一切默认就好,先解决问题后面再研究问题原因

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

    数据挖掘工程师:如何通过百度地图API抓取建筑物周边位置、房价信息

    因此,本文的目标是用一个rails应用配合js脚本来实现这种自动化抓取和储存,思路是js脚本负责与百度地图Api交互,rails服务器端负责储存抓取的数据,js和rails服务器用ajax方式传递数据....前提是rails服务器里已经有相应的房屋数据,如房屋的街道地址,小区名字等. 接下来需要做的就是为周边信息数据建表以及相应的关联表(因为它们为多对多关系) ?..., 创建相应的记录. attr中存放着每条周边数据经度,维度以及名字; obj为类名,如Bus, Subway, 通过find_by()方法查询这个经度和维度是否已经存在,若已经存在此记录, 说明之前存过了...,因为同一片区域的房子可能会有公有的基础设施; 若不存在,则创建新的记录. asso_obj为关联表,如BusesHouses, 这是由于bus和house为多对多关系: 一个公交车站附近有多个房屋,一个房屋附近也有多个公交车站...), 因此有几类周边类型,就需要多少个关联表,本文共有Bus, Hospital, Work, School, Subway, Shop 6类周边数据, 所以需要维护6个关联表,BusHouses是其中的一种

    4K90

    单点登录(二)| OAuth 授权框架及 CAS 在为 Web 应用系统提供的解决方案实践

    ,也可能在XML文件中检索用户密码等,CAS均提供一种灵活但统一的接口/实现分离的方式,CAS协议是分离的,这个认证的实现细节可以自定义和扩展; CAS client CAS client部署在客户端,...否则,cas server记录用户登录成功。并向浏览器回送cookie,记录用户已经登录成功。如果浏览器不支持cookie,则无法实现单点登录。...gitlab_rails['omniauth_allow_single_sign_on'] = false 3.使用root账号将普通gitlab账号和cas账号关联和解除关联 除了用户自己可以进行gitlab...账号和cas账号的关联外,root账号可以为所有gitlab 账号关联cas账号。...普通gitlab账号和cas账号的关联的解除和修改 与上面关联账号的步骤一样,登录root账号,进入admin area,选择users,点解需要解除关联cas账号的用户,选择identities。

    5.2K10

    用 Elasticsearch 统计做了几次核酸检测?怎么破?

    Q2:请教下大家,业务场景要记录每个人的每天的出勤情况,今天出勤标记为1或者当天日期,未出勤不记录,或者为0,有个个人信息索引,那么这个出勤情况改怎么存储,用数组?还是这种场景不适合es?...MySQL 支持事务ACID 特性且支持多表关联,但太多表关联会有性能问题,《阿里巴巴Java开发手册》有强调“超过三个表禁止 Join” Elasticsearch 更擅长大规模数据量级别的全文检索...Elasticsearch 支持的关联方式核心就如下几大类: 宽表方案 nested 嵌套文档实现 join 父子文档实现 业务层面自己实现 本文是建立在选型 Elasticsearch 作为核酸检测存储方案的基础上...着重说一下检索部分,检索部分用脚本实现。 第一:统计了数组大小,数组大小必须的大于我们要求的检索值大小,否则没有意义。 第二:统计各个时间字段是否在给定检索要求的时间范围内,如果在,就加1。...5、Elasticsearch Nested 嵌套实现 5.1 nested 建模 DELETE nucleic_testing_infos_nested PUT nucleic_testing_infos_nested

    77020

    ruby on rails + mysql 开发环境搭建

    (代码写完了并保存为.rb文件以后,直接F5就可以运行) 2.安装rails,命令行键入: gem install rails 不知道什么原因,我的机器(windows 2008 sp2)上一直提示如下错误...这里可以看到rails项目默认使用的是SQLite做为数据库,点击"About your application’s environment"将显示如下信息: ?...:http://download.mysql.cn/src/2008/1201/5556.html,按步就班的一步步安装,注意语言选择,建议选utf8 提示:最好安装4.1或5.0版本,不要安装最新的5.1...版本,rails框架对5.1版本的mysql支持并不好,在rake db:migrate时总提示出错 5.2 找一款适合自己的mysql管理工具,如果你是php程序员,phpmysqladmin也许很适合你...ok,基本上搞定了,好好享受ROR的乐趣吧。 其它问题请参见:司徒正美先生的 搭建rails运行环境

    3.8K50

    Rails路由

    belongs_to :magazine end 通过嵌套路由来反映模型关联: resources :magazine do resources :ads end ?...end 但是显然嵌套太深是非常麻烦的,经验告诉我们嵌套资源层级不应该超过一层,而避免嵌套过深的方法之一就是把动作集合放在父资源中,这样既可以表明层级关系,又不必嵌套成员动作: resources :articles...会自动确定对应的路由: Rails能够识别各个实例,自动使用 magazine_ad_path...: {format: 'jpg'} Rails会把 /photos/12 路径映射到 Photos#show 动作上,并把 params[:format] 设为 'jpg' 当然 defaults 还有块的形式...和 edit 动作上 限制创建的路由 Rails 默认会为每个 REST 式路由创建7个默认动作,可以使用 :only 和 :except 选项来微调此行为。

    4.5K20

    【数据库设计和SQL基础语法】--连接与联接--多表查询与子查询基础(二)

    子查询可以嵌套在 SELECT、FROM、WHERE 或 HAVING 子句中,用于从数据库中检索数据或执行其他操作。子查询通常返回一个结果集,该结果集可以被包含它的主查询使用。...2.3 子查询在多表查询中的嵌套应用 在多表查询中,子查询的嵌套应用可以帮助解决更为复杂的数据检索问题。...子查询中的条件将项目表与分配表关联起来,以获取每个项目的员工数量。 这样的嵌套子查询可以应用于多表查询的各种情况,例如计算聚合函数、获取相关信息等。...适当使用 JOIN 语句可以帮助你在单个查询中检索到需要的关联数据,提高查询的效率和灵活性。...五、常见问题与解决方案 5.1 多表查询常见错误 在进行多表查询时,有一些常见的错误可能会影响查询的正确性或性能。

    35710

    深圳软件测试学习:oracle数据库—子查询--千锋

    :返回的结果是一列的一个内容,出现几率最高 · 单行子查询:返回多个列,有可能是一条完整的记录 · 多行子查询:返回多条记录 在使用子查询的时候注意一下事项: 1.子查询必须用()括起来 2.子查询中不能包括...order by子句 3.子查询允许嵌套多个,但是不要超过255个 一、单行子查询 单行子查询是指返回一行数据的子查询语句。...,必须使 1.使用in运算符 只要匹配一个结果成功,就会返回检索记录 案例:查询不是销售部门(sales)的员工信息 select * from emp where deptno in (select...deptno from dept where dname ‘SALES’); 三,关联子查询 关联子查询 内查询的执行需要借助于外查询,而外查询的执行又离不开内查询的执行,这时,内查询和外查询是相互关联的...,这种查询方式被称为关联子查询 案例:检索工资大于同职位的平均工资的员工信息 select empno,ename,sal from emp f where sal >(select avg(sal

    70320

    MySQL的JOIN到底是怎么玩的

    INNER JOIN(内连接,或称为等值连接):此操作获取了两个表中字段相互匹配的记录,实质上是取得了这两个表的交集部分。...LEFT JOIN(左连接):相较于内连接,左连接获取了左表格的所有记录,即便在右表格中可能没有对应的匹配记录。这样,查询结果将包含两个表格的交集部分,以及左表格中的所有数据。...嵌套循环算法 MySQL通常采用嵌套循环(Nested-Loop Join)的方法来执行关联查询,具体而言,主要包括简单嵌套循环连接(Simple Nested Loop Join)、块状嵌套循环连接(...在内存中自行关联:首先从数据库中检索数据,然后在程序中执行第二次查询,随后进行关联操作。...在此之前,MySQL通常使用嵌套循环(Nested-Loop Join)的方法来执行关联查询,然而嵌套循环算法在性能方面并不理想。

    23710

    SQL优化

    Java适配的MySQL数据库默认提供每张数据记录表的索引表机制。数据库表的数据索引默认是会查找索引表之后再去数据记录表中查找数据。...like 查询是全表扫描操作,全表扫描关联的数据量过大的时候会产生数据查询时间过长。二叉树索引的增强版本B+树实现对索引的树形结构存储。树形结构存储数据库的索引比线性数组存储性能要好。...SQL的编写过程涉及到的子查询不能嵌套太多,子查询会在运行内存中给数据输出对象分配内存空间。嵌套分配内存不利于内存空间的释放。表与表之间的关联关系建立通过外键和主表的主键进行关联。...SQL的数据输出数据区尽量使用简单的数据。聚集函数在SQL的输出数据区存在会生成数据输出集合,类似复杂数据对象不利于数据的检索。聚集函数输出数据会产生索引失效,需要重新对输出数据建立索引。...SQL的条件过滤is null 是不会扫描索引表。节省数据索引表的内存空间。条件or关键字尽量少用,也是不会和数据索引表产生关联。数据表的小表类似索引表,大表类似数据库记录表。

    14310

    Elasticsearch索引之嵌套类型:深度剖析与实战应用

    Nested嵌套类型: 这是一种更为紧凑和高效的方式来处理嵌套文档,允许在单个文档中直接嵌套其他文档,并保持它们之间的关联性,便于进行复杂的查询操作。...三、嵌套类型的定义 在Elasticsearch中,嵌套类型主要用于处理包含多个内部对象的字段,这些内部对象通常与外部对象相关联。...这种数据结构允许我们存储多个与用户相关的记录,并保持它们之间的关联性。 五、查询嵌套文档 查询嵌套文档时,需要使用特定的nested查询语法。...通过nested查询,可以精确地定位到嵌套字段中的特定数据,并进行高效的检索。 六、排序和聚合 除了基本的查询功能外,Elasticsearch还允许我们对嵌套字段进行排序和聚合操作。...通过正确使用嵌套索引、查询、排序和聚合功能,你可以高效地检索和分析关联数据。然而,在使用嵌套索引时需要注意性能影响和查询复杂性,并根据具体情况考虑替代方案来优化数据模型和查询性能。

    58310

    ROR学习笔记(1):Rails 2快速创建GRUD应用

    机器上没安装ROR开发环境的朋友,请先参看 ruby on rails + mysql 开发环境搭建 架好环境 注:ROR的经典著作“Web开发敏捷之道--应用Rails进行敏捷Web开发”目前中文的只有第二版...,作者写书的环境是rails 1.x,现在rails的版本已经更新至2.3.5,很多东西已经变了,如果参考第二版的书上一步步来做的话,根本做不下去。...363605 这里可以下载该书英文电子版) 以下操作命令,均在windows 命令行模式下完成  1.进入工作目录(本例为d:\mydoc\ror\) d: cd mydoc\ror 2.创建带mysql的rails...项目:depot (项目名称可随便起,不一定要用depot) D:\MyDoc\Ror\depot>rails -d mysql depot 3.编辑database.yml,修改username与password...,同时在mysql中把database.yml对应的数据库建好(注意编码建议选择为utf8) 注意:mysql不要安装最新的5.1版本,建议用5.0版本,否则rake在做数据库迁移时,可能会出现问题.

    2K90

    gitlab服务部署及使用

    index的目录树到本地仓库,方便下一步通过git push同步本地仓库与远程仓库的同步 index暂存区: .git目录下的index文件,暂存区会记录git add 添加文件的相关信息(文件名...:轻量级的反向代理服务器(这个是个敏捷的反向代理,它会处理一些大的HTTP请求,比如文件的上传下载,其他的请求会反向代理给Gitlab Rails应用) logrotate:日志文件管理工具 postgresql...:数据库 redis:缓存数据库 sidekiq:用于在后台执行队列的任务 unicorn:Gitlab Rails应用是托管在这个服务器上面的 优点 git是分布式的,svn不是 git分布式本地就可以用...git有一个强大的代码仓库管理系统 - gitlab 可以很方便的管理权限、代码review,创建、管理project 五、安装配置gitlab 5.1....['smtp_enable'] = true gitlab_rails['smtp_address'] = "smtp.163.com" gitlab_rails['smtp_port'] = 25 gitlab_rails

    2.3K20

    一次浴火重生的MySQL优化(EXPLAIN命令详解)

    业务场景: 分区统计XXX省每月上传数据的企业数量,何为企业是否是未上传数据,即专门存放上传数据的数据表中没有记录的为未上传数据的企业,如果有那么代表已经上传数据。...3、table :对应行正在访问哪一个表,表名或者别名(注意:MySQL对待这些表和普通表一样,但是这些“临时表”是没有任何索引的); 关联优化器会为查询选择关联顺序,左侧深度优先 当from中有子查询的时候...个人建议:该值如果比整表总记录数越低,则越好。   ...因为我上面的那条语句是一个子查询,所以我首先根据id的值找到最先执行的检索语句,也就是嵌套在最内层的那条等值查询语句,它分别使用等值条件去连接企业表和上传数据表筛选出符合条件的数据,但是使用EXPLAIN...,并且在匹配的时候org表的主键索引也真正使用到了,级别达到了eq_ref,至于info表的ALL级别,毋庸置疑业务需要必须就是要去扫描整表的;最后看到最外层的检索语句也未必是高效的,它关联的地区表也进行了全表数据匹配

    98050

    多表连接的三种方式详解 hash join、merge join、 nested loop

    二.SORT MERGE JOIN:排序合并连接 Merge Join 是先将关联表的关联列各自做排序,然后从各自的排序表中抽取数据,到另一个排序表中做匹配。...驱动表中的每一行与inner表中的相应记录JOIN。类似一个嵌套的循环。 对于被连接的数据子集较小的情况,嵌套循环连接是个较好的选择。...在嵌套循环中,内表被外表驱动,外表返回的每一行都要在内表中检索找到与它匹配的行,因此整个查询返回的结果集不能太大(大于1 万不适合),要把返回子集较小表的作为外表(CBO 默认外表是驱动表),而且在内表的连接字段上一定要有索引...适用情况: 适用于驱动表的记录集比较小(的访问方法(Index),并且索引选择性较好的时候....JOIN的顺序很重要,驱动表的记录集一定要小,返回结果集的响应时间是最快的。 ?

    6.4K10
    领券