Table des matières
回复内容:
Maison développement back-end tutoriel php PHP和mysql中,如何防止数据重复insert?

PHP和mysql中,如何防止数据重复insert?

Jun 06, 2016 pm 08:46 PM
php

因为运行的时候有延迟。

sql1 = SELECT * FROM posts WHERE mid = 2

sql2 = INSERT INTO posts (id,mid,other) VALUES ('',".$c.",'def');

因为用了for 循环。首先是检测是否存在Sql1,如果不存在,则sql2。
再重复循环。可是,当前sql2第一次没有运行insert时,第二次循环的时候执行Sql1是通过的,然后再次执行sql2,导致运行了两次sql2。

可能同时触发了一个链接,这样导致重复插入了。
综合几位朋友的说法,我决定不在这个循环里面插入数据。

但好像:
用 INSERT INTO posts (id,mid,other) VALUES ('',".$c.",'def'),('','c2','def2'),('','c2','def2'),('','c2','def2');
这样子不行,因为假如其中一个出错,那么整条就好像就不能插入了。

谢谢大家的解答,我再去试了下我想到的几种方式~谢谢~

这个要怎么处理呢?

听说要用事务处理,但是不懂如何使用。手册已经看过了,但不明白。。。

[以下只是举例子]
$c 是 变量, mid 字段不能设置为“唯一”

<br>$c = '10000';
for($a = 0;$a < 100; $a++){
    $sql1 =  "SELECT * FROM `posts` WHERE `mid` = ".$c;
    $query1 = mysql_query($sql1);
    $row = mysql_num_rows($query1);

    if($row == 0){
        $sql2 = "INSERT INTO `posts` (`id`,`mid`,`other`) VALUES ('',".$c.",'def')";
        $query2 = mysql_query($sql2);
    }
Copier après la connexion
Copier après la connexion

}

回复内容:

因为运行的时候有延迟。

sql1 = SELECT * FROM posts WHERE mid = 2

sql2 = INSERT INTO posts (id,mid,other) VALUES ('',".$c.",'def');

因为用了for 循环。首先是检测是否存在Sql1,如果不存在,则sql2。
再重复循环。可是,当前sql2第一次没有运行insert时,第二次循环的时候执行Sql1是通过的,然后再次执行sql2,导致运行了两次sql2。

可能同时触发了一个链接,这样导致重复插入了。
综合几位朋友的说法,我决定不在这个循环里面插入数据。

但好像:
用 INSERT INTO posts (id,mid,other) VALUES ('',".$c.",'def'),('','c2','def2'),('','c2','def2'),('','c2','def2');
这样子不行,因为假如其中一个出错,那么整条就好像就不能插入了。

谢谢大家的解答,我再去试了下我想到的几种方式~谢谢~

这个要怎么处理呢?

听说要用事务处理,但是不懂如何使用。手册已经看过了,但不明白。。。

[以下只是举例子]
$c 是 变量, mid 字段不能设置为“唯一”

<br>$c = '10000';
for($a = 0;$a < 100; $a++){
    $sql1 =  "SELECT * FROM `posts` WHERE `mid` = ".$c;
    $query1 = mysql_query($sql1);
    $row = mysql_num_rows($query1);

    if($row == 0){
        $sql2 = "INSERT INTO `posts` (`id`,`mid`,`other`) VALUES ('',".$c.",'def')";
        $query2 = mysql_query($sql2);
    }
Copier après la connexion
Copier après la connexion

}

问题描述的不是很清晰,

可是,当前sql2第一次没有运行insert时,第二次循环的时候执行Sql1是通过的,然后再次执行sql2,导致运行了两次sql2。

上面这句话没看懂什么意思

首先,在循环里面做sql查询是相当低效的,强烈建议你修改逻辑,避免这种情况

关于你举例子的那段for循环代码,两个优化方案
其一,在循环里拼接insert的数组,大概代码如下

$d = [];
for($i = 0; $i < 100; $i++)
{
    $r = mt_rand(1, 100);
    //排除重复值,
    if(!in_array($r, $d))
    {
         $d[] = $r;
    }
}
$pdo = new PDO($dsn, $user, $passwd);
$pdo->prepare("insert into table(col1,col2) values(?,?)");
foreach($d as $v)
{
    $pdo->execute(array($v, $v));
}
Copier après la connexion

如上,复用insert语句模板,同时也排除了可重复插入的数值,如果对每一组值有特殊处理,也可以放在foreach处理
我很推荐你使用此种方式,这种方式也是安全的,能良好的预防sql注入,而无需你再去考虑太多sql注入的问题

其二,拼接一个比较长的insert的语句,

insert into table_name(col1,col2, ......) values(v1,v2,......),(v1,v2,......),......
Copier après la connexion

上述二者可能并不切合题意,因为可能之前库里就存在和当前插入有重复的数据
在mysql里有如下sql语法

INSERT INTO TABLE (a,b,c)
VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1;
Copier après la connexion

上句中的意思就是,插入一条语句到表中,如果插入的数据和表中唯一索引或者主键重复,更新字段c的值

结合这个sql语句,能很完美解决插入值重复的问题吧?

循环里敢这么玩!

不懂你这个$sql1判断的意义何在,设置id这个是唯一key不就好了么?而且同 @宋小北 循环里面敢这么玩!!

今天看到个文章和这个问题非常契合,特此补上:http://blog.sae.sina.com.cn/archives/3491 -2014/04/17 12:41

只要在'posts'的表,加上唯一UNIQUE即可,或者當然可以用

INSERT INTO
table(column1,column2,column3 ...columnN)
SELECT value1,value2,value3 ...valueN
FROM dual
WHERE NOT EXISTS(
SELECT *
FROM table
WHERE value = ?
);

先查询可用的mid, 再插入数据

$variable_array = array();
$c = 1000;
for($a = 0;$a < 100; $a++){
    $variable_array[] = $c;    
}
if (count($variable_array) == 0) {
    return false;
}
// 去重
$variable_array = array_unique($variable_array);
// 获取可用mid
$sql_head = "SELECT `mid` FROM `posts` WHERE `mid` in (#variable#) ";
// 加上单引号, 如果确定都是数字,那就不加
$mid_array = array_map(function($value){return "'$value'";}, $variable_array);
$mid_list = array();
foreach (array_chunk($mid_array, 500) as $piece) {
    $variable_str = implode(",", $piece);
    $sql_piece = str_replace("#variable#", $variable_str, $sql_head);
    $query_piece = mysql_query($sql_piece);
    // 获取mid $mid_piece
    $mid_piece = mysql_fetch_array($query_piece);
    $mid_list = array_merge($mid_list, array_diff($piece, $mid_piece););
}
// 插入数据库
$insert_str_array = array_map(function($value){return "('', '$value', 'def')";}, $mid_list);
$insert_head = "INSERT INTO `posts` (`id`,`mid`,`other`) VALUES ";
foreach (array_chunk($insert_str_array, 500) as $piece) {
    $variable_str = implode(",", $piece);
    $insert_sql = $insert_head.$variable_str;
    mysql_query($insert_sql);
}
Copier après la connexion

很久没写php代码, 怎么获取mysql_query结果忘记了!!!直接用得mysql_fetch_array.

1.唯一索引。2.按照特征拿相关数据,进行对比

试试

<code>replace into `table` values set  key=val
</code>
Copier après la connexion
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Routage CakePHP Routage CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

Journalisation CakePHP Journalisation CakePHP Sep 10, 2024 pm 05:26 PM

Se connecter à CakePHP est une tâche très simple. Il vous suffit d'utiliser une seule fonction. Vous pouvez enregistrer les erreurs, les exceptions, les activités des utilisateurs, les actions entreprises par les utilisateurs, pour tout processus en arrière-plan comme cronjob. La journalisation des données dans CakePHP est facile. La fonction log() est fournie

See all articles