昨天刚接触 表名: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中的随机数目的元素名,请各位帮看看具体是哪里有问题了。

因为接触


回复讨论(解决方案)

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语句

登录后复制

array_rand() 函数从数组中随机选出一个或多个元素,如果选出的元素不止一个,则返回包含随机键名的数组,否则返回该元素的键名。

登录后复制
登录后复制

登录后复制
登录后复制



兄弟,不好意思,已经按照2楼大神的结果测试成功了,分给他了,非常感谢您认真的回复,抱歉占用您的时间为我解决问题,非常感谢!对不起啊。

把rand的参数 换成 数组的长度应该更好一点。

09-18 10:15