昨天刚接触PHP,想做个这样的需求:通过一个PHP代码,可以随机生成随机数目的值,插入到数据库中,结构如下:
表名:test
字段名: 用户id aihao
值: 1 吃饭
值: 20 吃饭,睡觉
值: 35 吃饭,睡觉,打豆豆
值: 203 睡觉,打豆豆
其中用户ID是已经存在的,无需修改。爱好的值是需要随机赋予的。我写的代码是这样的:
for($i=0;$i<4;$i++){ $aihao=array("吃饭","睡觉","打豆豆"); $rn=rand(1,3); $result=array_rand($aihao,count($rn));$sql="replace into test(aihao) values ($result)";$re=mysql_query($sql);}
运行结果为固定的1位数字,并不是array中的随机数目的元素名,请各位帮看看具体是哪里有问题了。
因为接触PHP还不到2天,上述代码都是百度出来的,我觉得问题可能出在对array_rand函数理解不够上面,根据PHP帮助文档的内容,实在看不出来该怎么改了,希望大家能指点指点,谢谢。
回复讨论(解决方案)
array_rand() 返回的是数组中随机元素的键名
改成下面这样:
//$result=array_rand($aihao,count($rn));$result=$aihao[array_rand($aihao,count($rn))];
1.$aihao这个变量既然不被修改,应该定义在循环之外
2.查了下手册,array_rand返回的是随机键而不是值,你定义$aihao没有指定键,那就是0,1,2了
3.$rn本身就是想要一个随机个数,为什么还要加count呢?
4.$result在多个值的情况下是数组,不能直接写入sql语句
<?php$aihao = array("吃饭", "睡觉", "打豆豆");$aihao = array_flip($aihao);for ($i = 0; $i < 4; $i++) { $rn = rand(1, 3); $result = array_rand($aihao, $rn); $result = is_array($result) ? implode(',', $result) : $result; echo $result . '<br />';}
array_rand() 函数从数组中随机选出一个或多个元素,如果选出的元素不止一个,则返回包含随机键名的数组,否则返回该元素的键名。
<?php header("Content-type:text/html;charset=utf-8"); $aihao=array("吃饭","睡觉","打豆豆"); $aihao=array_flip($aihao); $arr=array_rand($aihao,rand(1,3)); $rs=is_array($arr)?implode(',',$arr):$arr; //echo $sql;?>
<?php header("Content-type:text/html;charset=utf-8"); $aihao=array("吃饭","睡觉","打豆豆"); $aihao=array_flip($aihao); $arr=array_rand($aihao,rand(1,3)); $rs=is_array($arr)?implode(',',$arr):$arr; //echo $sql;?>
兄弟,不好意思,已经按照2楼大神的结果测试成功了,分给他了,非常感谢您认真的回复,抱歉占用您的时间为我解决问题,非常感谢!对不起啊。
把rand的参数 换成 数组的长度应该更好一点。

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,关注台词:1)启用opcodeCachingwithapCutoredUcescriptexecutiontime.2)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

依赖注入(DI)通过显式传递依赖关系,显着提升了PHP代码的可测试性。 1)DI解耦类与具体实现,使测试和维护更灵活。 2)三种类型中,构造函数注入明确表达依赖,保持状态一致。 3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)

phpisusedforsenderemailsduetoitsbuilt-inmail()函数andsupportiveLibrariesLikePhpMailerandSwiftMailer.1)usethemail()functionforbasicemails,butithasimails.2)butithasimimitations.2)

PHP性能瓶颈可以通过以下步骤解决:1)使用Xdebug或Blackfire进行性能分析,找出问题所在;2)优化数据库查询并使用缓存,如APCu;3)使用array_filter等高效函数优化数组操作;4)配置OPcache进行字节码缓存;5)优化前端,如减少HTTP请求和优化图片;6)持续监控和优化性能。通过这些方法,可以显着提升PHP应用的性能。

依赖性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增强量产生性,可验证性和Maintainability.itallowspasspassingDepentenciesLikEdenceSeconnectionSeconnectionStoclasseconnectionStoclasseSasasasasareTers,interitationApertatingAeseritatingEaseTestingEasingEaseTeStingEasingAndScalability。

cachingimprovesphpermenceByStorcyResultSofComputationsorqucrouctationsorquctationsorquickretrieval,reducingServerLoadAndenHancingResponsetimes.feftectivestrategiesinclude:1)opcodecaching,whereStoresCompiledSinmememorytssinmemorytoskipcompliation; 2)datacaching datacachingsingMemccachingmcachingmcachings


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。