求php页面不重复提交和不重复插入数据的解决办法????
?php
创新互联是专业的扎囊网站建设公司,扎囊接单;提供网站制作、网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行扎囊网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
session_start();
$id_lucky = $_POST['id_lucky'];
$customer = $_POST['customer'];
$prize = $_POST['prize'];
$hide = $_POST['hidden'];
//var_dump($_SESSION);
if($hide==$_SESSION['conn'])//你这里判断的session是什么时候存入session的
{
$sql=mysql_query("insert into "._DB_PREFIX_."luckdraw (customer,prize) values ('$customer','$prize')");
//你这里没有判断 你应该在这里判断一下mysql_query是否执行成功 执行sql成功 是提交成功 否则是失败 建议你使用var_dump($sql)打印$sql看看$sql是什么数据类型
if($sql){
echo "亲,提交成功了哦";
}else{
echo '失败';
}
}else
{
echo "scriptreturn false;/script";
}
session_destroy();
PHP 导入excel数据到mysql 如果有重复的字段则插入失败,只要有一条重复则所有数据都无法插入
把数据表引擎用InnoDB,开启事务,判断只要有一条重复则回滚rollback,否则commit
thinkphp 数据库插入时重复插入
你在插入之前要先对数据进行一次过滤也就是逻辑上得唯一判断后再作入库处理,否则提示已存在不插入即可。
php 如何避免刷新页面重复插入数据到数据库
每次进入提交的页面,给一个session,为了避免重复,session的key可以是随机的。
在表单填写页面
?php
session_start(); // 启用session
$time = time();
$key = 'sess_' . $time; // 根据时间生成一个随机的session key
$_SESSION[$key] = $time; // 设置session的值
?
!--{通过隐藏表单将 session 的 key传递到服务端处理}--
input type="hidden" name="session_key" value="?php echo $time;?" /
处理页面
?php
session_start(); // 启用session
$key = $_POST['session_key'];
if(!$key || $_SESSION[$key] != substr($key, 5)){
// 如果没有传 session_key 参数
// 或者 session_key 参数值截断 sess_后的数字 与 session参数值不匹配
unset($_SESSION[$key]); // 删除 session 值
// 然后考虑是否要提示错误,或者转入另一个页面
exit(); // 终止页面代码执行
}
// 下面进行数据写操作
// 数据操作完成后,删除session
unset($_SESSION[$key]);
// 后续操作
?
$########################
一个页面也是一样的,我给你的只是一个思维,
具体如何实现,你要根据自己的实际情况去处理
很多东西都不是通用的
另外,不管多少个页面,必然包含两个部分,一部分是表单填写,一部分是数据处理,这个跟多少个页面无关~~就看你是否能够理解这段代码的意义,如果不理解的话,嵌套进去也没啥用,能够理解的话,或许你能够找出更适合自己的解决方案
当前题目:php不能重复添加数据 php添加数据到数据库没有反应
文章链接:http://lswzjz.com/article/dojpjjp.html