php输出mysql时用了do while嵌套do while循环,如何避免重复输出数据库内容?
遍历两次吧,第一次遍历出follower,再在里面嵌套一次遍历,条件就是第一次遍历时出来的follower,你试试看,不知道我有没有理解错误
PHP表单注册用户名重复,怎样不能提交?
if(!empty($row['name'])){$response = "<font color=red>该用户名已被注册!</font>";exit("<script>window.history.go(-1);</script>");}
PHP如何实现删除数组元素和重新索引?
如果要在某个数组中删除一个元素,可以直接用的unset
<?php $arr = array('a','b','c','d'); unset($arr[1]); print_r($arr); ?> print_r($arr)
之后,结果却不是那样的,最终结果是 Array ( [0] => a [2] => c [3] => d )
那么怎么才能做到缺少的元素会被填补并且数组会被重新索引呢?答案是
array_splice():
<?php $arr = array('a','b','c','d'); array_splice($arr,1,1); print_r($arr); ?>
print_r($arr)之后,结果是A(www.111cn.net)rray ( [0] => a [1] => c [2] => d )
删除数组指定元素
array_search()比较实用
array_search() 函数与 in_array() 一样,在数组中查找一个键值。如果找到了该值,匹配元素的键名会被返回。如果没找到,则返回 false$array = array('1', '2', '3', '4', '5');$del_value = 3;unset($array[array_search($del_value , $array)]);//利用unset删除这个元素print_r($array);输出array('1', '2', '4', '5');
但这种如果要重新索引数组就需要利用foreach遍历删除的数组之后重新建立一个数组这样也是可以的。
php生成唯一id的几种解决方法?
网上查了下,有很多的方法1、md5(time() . mt_rand(1,1000000)); 这种方法有一定的概率会出现重复2、php内置函数uniqid() uniqid() 函数基于以微秒计的当前时间,生成一个唯一的 ID. w3school参考手册有一句话:"由于基于系统时间,通过该函数生成的 ID 不是最佳的。如需生成绝对唯一的 ID,请使用 md5() 函数"。
PHP如何避免表单的重复提交?
1. 使用JS让按钮在点击一次后禁用(disable)。采用这种方法可以防止多次点击的发生,实现方式较简单。缺点是若客户端禁止JavaScript脚本,则失效。
2. 在提交成功后执行页面重定向(redirect)。转到提交成功信息页面。特点:避免F5重复提交,消除浏览器前进和后退按钮可导致的同样问题。
3. 表单隐藏域中存放session(表单被请求时生成的标记)。采用此方法在接收表单数据后,检查此标志值是否存在,先进行删除,然后处理数据; 若不存在,说明已提交过,忽略本次提交。
4. 数据库唯一索引约束(最有效的防止重复数据的方法)。
5. 使用验证码