- 博客(203)
- 资源 (4)
- 收藏
- 关注
原创 MySQL 隐式类型转换导致索引失效问题
比如将查询条件由 1005 变成 1005aa,发现也同样能查询到 1005 的数据,这是因为MySQL在进行字段值比较的时候,发生了隐式类型转换,将 1005aa 转换成浮点型 1005 进行比较,所以能查询出 1005 的记录。首先发现 no_str 索引失效了,并且结果也不是预期结果,会将额外的数据查询出来,比如查询 1005 会把 1005aa 的记录也查出来,这是因为MySQL进行了隐式类型转换,换成了浮点型进行比较。这个没什么说的,不管是查询结果和使用索引都达到预期效果。
2022-10-15 15:32:29 1988
原创 MySQL提示sql_mode=only_full_group_by解决办法
对于group by聚合操作,select中的列只能是出现在group by中的列,使用聚合函数除外,如max()、min()等。这个方法的好处是不用重启MySQL生效(需要注意的是在当前会话实例中是不生效的),坏处是重启后会恢复原样。在MySQL 5.7后MySQL默认开启了SQL_MODE严格模式,对数据进行严格校验。会报sql_mode=only_full_group_by错误说明写的SQL语句不严谨,将分到同一组的数据里第一条数据的指定列值作为返回数据。如果语句太多,变动太大,可以改数据库配置。
2022-09-11 16:39:22 4411
原创 Linux 下安装 node.js
这里介绍两种安装方式:编译安装和使用编译后的安装包安装。安装目录:/usr/local1、进入安装目录:2、下载安装包:3、解压:4、进入解压目录:5、编译安装:6、创建软链,在 usr/bin/ 目录下创建软链,实现全局运行:7、测试是否安装成功:1、进入安装目录:2、下载安装包:3、解压:4、重命名:5、创建软链,在 usr/bin/ 目录下创建软链,实现全局运行:6、测试是否安装成功:
2022-09-04 11:05:53 305
原创 Windows10 下使用 telnet 命令
打开控制面板-》程序和功能-》启用或关闭 Windows 功能。勾选 "Telnet客户端" 选项,点击确定。接下来就可以正常使用 telnet 命令了。
2022-09-04 10:54:46 1025
原创 crontab -e无法保存:/var/spool/cron/#tmp.localhost.localdomain.XXXXLjnf86: Operation not permitted
crontab -e无法保存:/var/spool/cron/#tmp.localhost.localdomain.XXXXLjnf86: Operation not permitted
2022-08-21 15:06:35 820
原创 Linux 下安装 redis
1、下载地址:http://download.redis.io/releases/下载版本:redis-6.2.7.tar.gz2、使用命令下载:3、将文件拷贝到安装目录 /usr/local 目录下4、进入 /usr/local 目录下,解压安装包5、进入解压后的目录6、编译,将 redis 安装到指定目录,如:/usr/local/redis7、如编译过程中出现问题: /bin/sh: cc: 未找到命令说明没有安装 gcc,使用 yum 安装即可:8、如编译过程中出
2022-07-02 22:27:04 627
原创 Golang环境安装
一、下载地址Golang:Downloads - The Go Programming LanguageGoLand编辑器:Download GoLand: A Go IDE with extended support for JavaScript, TypeScript, and databases二、安装1、Golang 安装安装完后可以测试一下,打开 cmd,输入 go version,如下图所示,安装成功。2、Go...
2022-05-04 16:59:41 940
原创 Linux 下统计文件夹下文件的数量
1、查看当前目录下的文件数量(不包含子目录中的文件)# ls -l 查询当前目录下文件的详细信息# grep "^-" 使用正则匹配,其中 ^ 表示锚定行的开始,- 表示文件,^- 表示匹配以 - 开始的行,即匹配文件# wc -l 表示统计输出信息的行数ls -l | grep "^-" | wc -l2、查看当前目录下的文件数量(包含子目录中的文件)# -R 表示包含子目录ls -lR | grep "^-" | wc -l3、 查看当前目录下的文件夹目录个数
2022-05-04 00:02:09 12745
原创 Linux 下重启 PHP 服务、nginx 服务
一、重启 PHP 服务service php-fpm start 开启service php-fpm stop 停止service php-fpm restart 重启二、重启 nginx 服务sudo service nginx start 开启sudo service nginx stop 停止sudo service nginx restart 重启sudo service nginx reload 重新加载...
2022-05-03 23:34:18 3415
原创 Python环境安装
一、下载地址:Python:Download Python | Python.orgPyCharm:Download PyCharm: Python IDE for Professional Developers by JetBrains选择需要的版本下载即可,其中专业版试用30天,社区版免费。二、安装1、Python 安装:选择 Customize installation 自定义安装,勾选 Add Python 3.10 to PATH(添加环境变..
2022-05-03 23:14:30 689
原创 MySQL实现 group_concat 排序
MySQL支持实现group_concat() 内部自定义排序:实例:新建一张表 reward,表中数据如下:SQL:SELECT uid, GROUP_CONCAT(money ORDER by money DESC) AS money_desc FROM reward GROUP BY uid DESC;结果:使用其他字段也一样的效果:SQL:SELECT uid, GROUP_CONCAT(id ORDER by money DESC..
2022-05-01 19:30:49 6130 3
原创 PHP设计模式—享元模式
定义:享元模式(Flyweight):运用共享技术有效地支持大量细粒度的对象。结构:Flyweight:享元抽象类,所有具体享元类的接口,通过这个接口,Flyweight 可以接受并作用于外部状态。 ConcreteFlyweight:实现 Flyweight 接口的可以共享的具体享元类。 UnsharedConcreteFlyweight:非共享的具体享元类。 FlyweightFactory:享元工厂,用来创建并管理 Flyweight 对象,它主要是用来确保合理地共享 Fly
2022-04-23 17:52:28 433
原创 PHP array_count_values()
array_count_valuesarray_count_values() 函数用于统计数组中所有值出现的次数。本函数返回一个数组,其元素的键名是原数组的值,键值是该值在原数组中出现的次数。示例:function arrayCountValues(){ $data = ['a', 'b', 'c', 'd', 'b', 'c', 'a', 'a']; $handle = array_count_values($data); return $handle;
2022-03-19 14:49:49 318
原创 PHP str_repeat()
str_repeatstr_repeat() 函数把字符串重复指定的次数。示例:function strRepeat(){ echo str_repeat("*", 5); // *****}
2022-03-19 14:44:59 442
原创 PHP array_values()
array_valuesarray_values() 函数返回一个包含给定数组中所有键值的数组,但不保留键名。示例:function arrayValues(){ $data = ["size" => "XL", "color" => "gold"]; $handle = array_values($data); return $handle; // ["XL","gold"]}...
2022-02-20 15:51:13 464
原创 PHP array_reduce()
array_reducearray_reduce()将回调函数callback迭代地作用到array数组中的每一个单元中,从而将数组简化为单一的值。示例一:public function arrayReduce(){ $data = [ ['a' => '10', 'b' => '30'], ['a' => '20', 'b' => '60'], ['a' => '30', 'b' =&g...
2022-01-23 15:22:22 324
原创 VMware Workstation 与 Device/Credential Guard 不兼容
问题:在确定已经禁用 Hyper-V 功能的前提下,启动虚拟机还是报错 "VMware Workstation 与 Device/Credential Guard 不兼容。在禁用 Device/Credential Guard 后,可以运行 VMware Workstation"。解决办法:1、打开本地服务,将 "HV 主机服务" 设置为 "禁用"。本地服务打开方式:此电脑-->管理-->服务和应用程序-->服务 快捷方式 Win + R,输入 servi
2021-12-05 15:10:34 1845
原创 WIN10下启动VMware虚拟机蓝屏的解决办法
问题:每次启动虚拟机就会蓝屏,提示错误代码:PAGE_FAULT_IN_NONPAGED_AREA解决办法:禁用 Hyper-V 功能打开“控制面板-->程序-->启用或关闭Windows功能”,之后在弹框中找到 Hyper-V 并取消勾选,重启生效。如果之前没有启用 Hyper-V 功能但是也出现蓝屏,则可以先启用,再禁用。控制面板可通过 Win+R,输入 control 来打开。...
2021-12-05 14:59:02 6824 2
原创 WIN10家庭版找不到Hyper-V的解决办法
问题:相比于 WIN10 专业版来说,WIN10 家庭版在 “启用或关闭Windows功能” 中找不到 Hyper-V 选项。但这并不意味着 WIN10 家庭版不支持 Hyper-V 功能,我们可以手动开启它。解决办法:1、首先要确定电脑是否支持 Hyper-V 功能。打开 Windows PowerShell,输入 systeminfo 命令:可以看到出现了很多处理器的信息,最末尾有个 Hyper-V 要求,如果四个全是 “是”,则表示支持 Hyper-V 功能。
2021-12-05 14:48:10 5405 5
原创 PHP中 empty() 和 isset() 的区别
区别:empty()函数用于检查一个变量是否为空。当一个变量并不存在,或者它的值等同于 FALSE,那么它会被认为不存在。如果变量不存在的话,empty()并不会产生警告。 isset()函数用于检测变量是否已设置并且非 NULL。如果已经使用 unset() 释放了一个变量之后,再通过 isset() 判断将返回 FALSE。若使用 isset() 测试一个被设置成 NULL 的变量,将返回 FALSE。同时要注意的是 null 字符("\0")并不等同于 PHP 的 NULL 常量。 对于 ..
2021-11-13 15:09:23 1545
原创 PHP中检测是否是有效邮箱
方法一:使用 filter_var 函数 FILTER_VALIDATE_EMAILfunction validateEmail($email){ if (!filter_var($email, FILTER_VALIDATE_EMAIL)) { echo '邮箱格式错误'; } else { echo '邮箱格式正确'; }}方法二:使用正则匹配function validateEmail($email)..
2021-11-13 14:58:41 2176
原创 HTTP错误状态码详解
HTTP 状态码分为 5 类,如下表所示: HTTP状态码分类 含义 1xx 信息 2xx 成功 3xx 重定向 4xx 客户端错误 5xx 服务器错误 下面详细说明一下各个状态码的作用:1xx100 Continue (继续) 收.
2021-11-13 14:49:12 3295
原创 Redis 过期删除策略和内存淘汰机制
Redis 设置过期时间Redis 有四个不同的命令可以用于设置键的生存时间(键可以存在多久)或过期时间(键什么时候会被删除):EXPIRE <key> <ttl> ——将键 key 的生存时间设置为 ttl 秒。 PEXPIRE <key> <ttl>——将键 key 的生存时间设置为 ttl 毫秒。 EXPIREAT <key> <timestamp>——将键 key 的过期时间设置为 timestamp...
2021-10-02 16:46:28 139
原创 PHP获取目录及子目录下所有文件名
思路:首先获取一个目录下所有文件名可以使用 scandir() 函数。scandir() 函数返回指定目录中的文件和目录的数组。因为这个返回的数据不包含子目录下文件,所以可以使用递归来处理。/** * @param $dir 要查找的文件路径 * @param $dir_array 存储文件名的数组 */function find_files($dir, &$dir_array){ // 读取当前目录下的所有文件和目录(不包含子目录下文件) $files
2021-10-02 14:48:46 3188 1
原创 PHP实现二分查找算法
二分查找二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查...
2021-10-02 10:05:33 2602
原创 MySQL 中 bigint、int、mediumint、smallint、tinyint 有符号和无符号的取值范围
想要了解取值范围首先需要知道的是 bit 和 Byte 的概念bit :位二进制数系统中,位通常简写为 "b",也称为比特,每个二进制数字 0 或 1 就是一个位(bit)。位是表示信息的最小单位,其中 8 bit 就称为一个字节(Byte)。Byte :字节字节(Byte)是用于计量存储容量的一种计量单位,是计算机中表示存储空间最基本的容量单位,字节通常简写为 "B"。bit 与 Byte数据存储是以“字节”(Byte)为单位,数据传输大多是以“位”(bit,又名“比.
2021-09-21 11:00:06 1188
原创 PHP 数组过滤空值 array_filter
PHP 提供了一个函数 array_filter 可以帮助我们更方便的过滤数组里面的空值。array_filter使用回调函数过滤数组的元素,返回过滤后的数组。 遍历array数组中的每个值,并将每个值传递给callback回调函数。 如果callback回调函数返回true,则将array数组中的当前值返回到结果array数组中。数组键名保持不变。 如果没有提供callback回调函数,将删除数组中array的所有“空”元素。示例一:// 不使...
2021-09-20 23:30:52 663
原创 redis将一个key设置为永不过期
这次介绍三个 redis 命令:Expire 命令用于设置 key 的过期时间,key 过期后将不再可用。单位以秒计。PERSIST 命令用于移除给定 key 的过期时间,使得 key 永不过期。TTL 命令以秒为单位返回 key 的剩余过期时间。ExpireEXPIRE key_name设置成功返回 1 。 当 key 不存在或者不能为 key 设置过期时间时(比如在低于 2.1.3 版本的 Redis 中你尝试更新 key 的过期时间)返回 0 。PERSI
2021-09-11 11:38:02 15153
原创 PHP构造函数和析构函数
构造函数__construct()PHP 允许开发者在一个类中定义一个方法作为构造函数。具有构造函数的类会在每次创建新对象时先调用此方法,所以非常适合在使用对象之前做一些初始化工作。class Car{ function __construct() { echo "这是构造函数" . "<br>"; }}// 创建对象时会调用__construct()$car = new Car(); // 这是构造函数...
2021-09-11 10:23:08 414
原创 MySQL执行一条查询语句的过程
执行流程如下图所示,我们可以看到当向 MySQL 发送一个请求时,MySQL 到底做了什么:客户端发送一条査询给服务器。 服务器先检查査询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果。否则进人下一阶段。 服务器端进行 SQL 解析、预处理,再由优化器生成对应的执行计划。 MySQL 根据优化器生成的执行计划,调用存储引擎的 API 来执行查询。 将结果返回给客户端。查询缓存在解析一个查询语句之前,如果查询缓存时打开的,那么 MySQL 会优先检查这个查...
2021-09-11 10:08:08 794 2
原创 session和cookie区别详解
什么是CookieHTTP协议是无状态协议,服务器本身无法判断用户身份,我们可以通过Cookie来跟踪用户状态,Cookie是一种在远程浏览器端存储数据并以此来跟踪和识别用户的机制。简单地说, Cookie是Web服务器暂时存储在用户硬盘上的一个文本文件,并随后被Web浏览器读取。一般情况下,Cookie通过HTTP headers从服务端返回到客户端。PHP通过setcookie函数进行Cookie的设置,任何从浏览器发回的Cookie,PHP都会自动的将他存储在$...
2021-08-28 21:29:54 169
原创 PHP设计模式—中介者模式
定义:中介者模式(Mediator):用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。结构:Mediator:抽象中介者,定义了同事对象到中介者对象的接口。 Colleague:抽象同事类。 ConcreteMediator:具体中介者对象,实现抽象类的方法,它需要知道所有具体同事类,并从具体同事接收消息,向具体同事对象发出命令。 ConcreteColleague:具体同事类,每个具体同事只知道自己的行
2021-08-27 21:29:13 219
原创 PHP设计模式—职责链模式
定义:职责链模式(Chain of Responsibility):使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。结构:Handler:抽象类,定义一个处理请示的接口。ConcreteHandler:具体处理者类,处理它所负责的请求,可访问它的后继者,如果可以处理该请求,就处理之,否则就将请求转发给它的后继者。Client:客户端代码。代码实例:/** * 抽象类,定义一个处理请示的接口
2021-07-26 21:31:54 206
原创 PHP设计模式—命令模式
定义:命令模式(Command):将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作。结构:Command:命令抽象类,用来声明执行操作的接口。ConcreteCommand:具体命令类,将一个接收者对象绑定于一个动作,调用接收者相应的操作。Invoker:命令发送者,要求该命令执行这个请求。Receiver:命令接收者,知道如何实施与执行一个请求相关的操作,任何类都可能作为一个接收者。Client:客户端代码,创建一个具体命令对
2021-06-29 21:02:46 246 2
原创 PHP设计模式—桥接模式
定义:桥接模式(Bridge):将抽象部分与它的实现部分分离,使它们都可以独立地变化。结构:Abstraction:抽象类。RefindAbstraction:被提炼的抽象类。Implementor:实现类。ConcreteImplementor:具体实现类 。Client:客户端代码。代码实例:接下来用代码实现一个颜色组合的例子,有三种颜色:黑、白、红,三种形状:圆形、正方形、长方形,可以自由组合。在这个例子中Abstraction表示形状,RefindAbstraction表示圆形
2021-06-29 20:50:10 163
原创 PHP中识别并解析URL
一、从字符串中识别URL可以使用正则表达式匹配function getUrl(){ $str = '提取urlhttp://127.0.0.1/demo/index'; $pattern = "/http[s]?:\/\/(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+/"; preg_match($pattern, $str, $matches); return $match
2021-06-29 20:08:55 557
dbforge studio for mysql 7.1.31 破解版
2018-07-01
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人