专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

mysql多表查询拼接,导致MySQL索引失效的原因有哪些呢_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/7 0:22:00       共计:3602 浏览
mysql多表查询拼接,导致MySQL索引失效的原因有哪些呢?

在PHP中如何在不使用第三变量的情况下,达到交换两个变量值得目的,这道题在面试题中经常出现,你是否掌握了?其实有很多种方法,更多的请看代码详细注释,接下来用心看看!

1 用函数substr() && strlen()

<?php/** * 双方变量为字符串时,可用交换方法一 * 使用substr()结合strlen()两个方法达到交换变量值得目的 */$a = "This is A"; // a变量原始值$b = "This is B"; // b变量原始值echo '交换之前 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出原始值$a .= $b; // 将$b的值追加到$a中/** * $b得到$a值详解: * 先通过strlen()分别计算出$a和$b中字符串的长度【此时$a是原始$a和$b的合值】 * 通过strlen($a)-strlen($b)即可得出原始$a的值长度 * 在通过substr()方法在合并后的$a中从0开始截取到$a的长度,那么即可得到原始$a的值 * $a得到$b值详解: * 由于此刻$b已经是$a的原始值了,而$a合并后的值为原始$a+原始$b的值,故用substr()在$a中从$b(原始$a)长度位置截取,则去的内容则为原始$b,则将$b值付给$a成功 */$b = substr($a,0,(strlen($a)-strlen($b)));$a = substr($a, strlen($b));echo '交换之后 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出结果值

运行结果:

交换之前 $a 的值:This is A, $b 的值:This is B

交换之后 $a 的值:This is B, $b 的值:This is A

2 用函数str_replace()

<?php/** * 双方变量为字符串时,可用交换方法二 * 使用str_replace()方法达到交换变量值得目的 * 此方法较第一种,逻辑上稍微简单点 */$a = "This is A"; // a变量原始值$b = "This is B"; // b变量原始值echo '交换之前 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出原始值$a .= $b; // 将$b的值追加到$a中$b = str_replace($b, "", $a); // 在$a(原始$a+$b)中,将$b替换为空,则余下的返回值为$a$a = str_replace($b, "", $a); // 此时,$b为原始$a值,则在$a(原始$a+$b)中将$b(原始$a)替换为空,则余下的返回值则为原始$b,交换成功echo '交换之后 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出结果值

运行结果:

交换之前 $a 的值:This is A, $b 的值:This is B

交换之后 $a 的值:This is B, $b 的值:This is A

三、用函数list() && array()

<?php/** * 双方变量为字符串时,可用交换方法三 * 使用list()和array()方法达到交换变量值得目的 * 此方法较第一、二种,代码最简洁 */$a = "This is A"; // a变量原始值$b = "This is B"; // b变量原始值echo '交换之前 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出原始值list($b,$a) = array($a,$b); // list() 函数用数组中的元素为一组变量赋值。了解这个,相信其他的不用我多说了吧echo '交换之后 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出结果值

运行结果:

交换之前 $a 的值:This is A, $b 的值:This is B

交换之后 $a 的值:This is B, $b 的值:This is A

四、异或

<?php/** * 双方变量为字符串或者数字时,可用交换方法四 * 使用异或运算 */$a = "This is A"; // a变量原始值$b = "This is B"; // b变量原始值echo '交换之前 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出原始值/** * 原始二进制: * $a:010101000110100001101001011100110010000001101001011100110010000001000001 * $b:010101000110100001101001011100110010000001101001011100110010000001000010 * * 下面主要使用按位异或交换,具体请参照下列给出的二进制过程, */$a=$a^$b; // 此刻$a:000000000000000000000000000000000000000000000000000000000000000000000011$b=$b^$a; // 此刻$b:010101000110100001101001011100110010000001101001011100110010000001000001$a=$a^$b; // 此刻$a:010101000110100001101001011100110010000001101001011100110010000001000010echo '交换之后 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出结果值

运行结果:

交换之前 $a 的值:This is A, $b 的值:This is B

交换之后 $a 的值:This is B, $b 的值:This is A

五、加(+)减(-)运算符

<?php/** * 双方变量为数字时,可用交换方法五 * 使用加减运算符,相当于数学运算了^_^ */$a = "This is A"; // a变量原始值$b = "This is B"; // b变量原始值echo '交换之前 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出原始值$a=$a+$b; // $a $b和值$b=$a-$b; // 不解释..$a=$a-$b; // 不解释..echo '交换之后 $a 的值:'.$a.', $b 的值:'.$b,'<br>'; // 输出结果值

运行结果:

交换之前 $a 的值:1, $b 的值:2

交换之后 $a 的值:2, $b 的值:1

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:统计mysql的查询,mysql一条sql怎么统计某个字段不同值的个数_数据库 | ·下一条:mysql 强制主查询,值得推荐的开源PHPCMS系统有哪些_数据库

Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有