项目迁移维护注意事项 - 对 composer 指令的重新认识
项目维护阶段与前期的开发阶段追求的点完全不同。开发阶段是开始迭代版本的时期,新功能开发、测试、整体测试、再开发、在测试...而维护阶段只关心一个字 - “稳”,有种“无为而治”的感觉。新项目上线,需要 git pull 代码,之后使用 composer 安装第三方库。需要强调的是,composer 指令中 composer install 才是真正的安装, composer update 是更新现
项目维护阶段与前期的开发阶段追求的点完全不同。开发阶段是开始迭代版本的时期,新功能开发、测试、整体测试、再开发、在测试...而维护阶段只关心一个字 - “稳”,有种“无为而治”的感觉。新项目上线,需要 git pull 代码,之后使用 composer 安装第三方库。需要强调的是,composer 指令中 composer install 才是真正的安装, composer update 是更新现
新版的云服务器上,ubuntu 系统默认登录用户就是 ubuntu。然后在 pull 代码和 composer 下载第三方库的时候,就会失败。需要注意的是,在 ubuntu 用户下创建的目录,下载的文件也可能属于 root 用户组。这时候需要修改文件或文件夹的所属:chown ubuntu.ubuntu www_folder # 遍历所有文件 chown -R ubuntu.ubuntu www_
以下为使用的 csv 格式输出代码: set_time_limit(0); header('Content-Language: zh'); header('Content-Type: application/vnd.ms-execl; charset=utf-8'); header('Content-Disposition: attachment;filename=&
问题说明遇到的情况类似于包含某商品的店铺订单总金额,订单明细表 -> 订单表关系为 n:1。如果明确商品 ID,可以将明细表与订单表关系约束为 1:1,这样计算的订单总金额就不会存在重复统计。但当前需要统计多个商品,这样如果直接通过多表联查并聚合统计店铺订单总金额就会存在重复统计的问题。当然可以直接绕过商品明细表,直接计算商铺订单总金额,但这样无法对商品进行约束。解决网络上有针对单表查询重复
先看一下函数语法:SUM(DISTINCT expression)如果在没有返回匹配行 SELECT 语句中使用 SUM 函数,则 SUM 函数返回 NULL,而不是0。DISTINCT 运算符允许计算集合中的不同值。SUM 函数忽略计算中的 NULL 值。在没有匹配行 SUM 会返回 NULL 而不是 0,这是我之前没有注意到的点。为了让结果不会 NULL 而是 0,可以使用 COALESCE(
因为发现密码重新生成(密码值不变)时,返回的 hash 值都会变化,而解密却都能够成功,所以对 Laravel 自带的这个获取加密 hash 值的方法突然比较好奇。\vendor\laravel\framework\src\Illuminate\Foundation\helpers.phpif (! function_exists('bcrypt')) { /** * Hash
公司的充电宝项目使用物联网技术连接设备,而与设备交互需要用到 TCP (或者 MQTT,性质一样)长连接。PHP 做这种项目大概率都会使用 workerman 框架(可以处理 TCP、Websockt 等请求),而业务框架 thinkphp 似乎也是首选。因为 thinkphp 可以将 wokerman 以扩展库的形式直接安装到框架中使用,过程非常简便。thinkphp 会在 config 下生成
在做一个数据维护工作的 php 脚本时,从插入数据库的记录中发现,数据记录被插入了两次。通过加入 Log 日志标记发现,问题源头在 foreach 循环执行上数据库操作上。查看循环对象,并没有重复记录,所以是 foreach 方法体本身执行了两次,这是我不能理解的。猜测与循环执行的数据库异步操作有关。以下为循环异步操作的代码示例: $orders = Orders::where('m
本来计算上线天数或注册天数是可以放到查询返回结果中处理的,但业务逻辑需要筛选上线天数达到7天、30天的记录,也就是说日期差值需要用在 where 子句中。这时需要 mysql 的库函数来帮忙处理了。涉及到处理时间差值的 mysql 库函数有这几个:TIMEDIFF()、DATEDIFF()、TIMESTAMPDIFF()。1. 使用 TIMEDIFF() 函数,求 time 差值timediff(
DB::enableQueryLog();//放在需要打印的查询前 User::all(); return DB::getQueryLog();//放在查询的后可以用 dd 直接输出:dd(DB::getQueryLog());