php插入数据判断主键重复,在MySQL数据库中,这4种方式可以避免重复的插入数据!...

80c276bd21dffff96d928ea9dd62937a.png

最常见的方式就是为字段设置主键或唯一索引,当插入重复数据时,抛出错误,程序终止,但这会给后续处理带来麻烦,因此需要对插入语句做特殊处理,尽量避开或忽略异常,下面我简单介绍一下,感兴趣的朋友可以尝试一下:

这里为了方便演示,我新建了一个user测试表,主要有id,username,sex,address这4个字段,其中主键为id(自增),同时对username字段设置了唯一索引:

01 insert ignore into

即插入数据时,如果数据存在,则忽略此次插入,前提条件是插入的数据字段设置了主键或唯一索引,测试SQL语句如下,当插入本条数据时,MySQL数据库会首先检索已有数据(也就是idx_username索引),如果存在,则忽略本次插入,如果不存在,则正常插入数据:

83174fe0cd9e41ee519be1165668dda0.png

02 on duplicate key update

即插入数据时,如果数据存在,则执行更新操作,前提条件同上,也是插入的数据字段设置了主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据(idx_username索引),如果存在,则执行update更新操作,如果不存在,则直接插入:

5c46e9df69105ce6aed69eebade1ba28.png

03 replace into

即插入数据时,如果数据存在,则删除再插入,前提条件同上,插入的数据字段需要设置主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据(idx_username索引),如果存在,则先删除旧数据,然后再插入,如果不存在,则直接插入:

723675d370f0210e2867bc406cdce468.png

04 insert if not exists

即insert into … select … where not exist ... ,这种方式适合于插入的数据字段没有设置主键或唯一索引,当插入一条数据时,首先判断MySQL数据库中是否存在这条数据,如果不存在,则正常插入,如果存在,则忽略:

5b4fd5728524fdbca7ecf2281315c9b8.png

目前,就分享这种MySQL处理重复数据的方式吧,前3种方式适合字段设置了主键或唯一索引,最后一种方式则没有此限制,只要你熟悉一下使用过程,很快就能掌握的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在将转换后的csv数据插入MySQL数据库PHP脚本,可以将MySQL的第一列id设置为自增序列,这样就不需要在csv文件添加这一列了。在建表时设置id为自增列的方法如下: ```sql CREATE TABLE your_table_name ( id INT(11) NOT NULL AUTO_INCREMENT, column1 VARCHAR(255), column2 VARCHAR(255), column3 VARCHAR(255), ... PRIMARY KEY (id) ); ``` 在上面的建表语句,id列被定义为自增列,并且设置为主键。这样,在插入数据时,可以不用管id列,MySQL会自动为每一行生成一个唯一的id值。 当然,如果你已经有了一个表,并且不想重新建表,也可以在插入数据时省略id列,MySQL会自动为每一行生成一个唯一的id值。具体的插入数据语句如下: ```php $servername = "localhost"; $username = "your_username"; $password = "your_password"; $dbname = "your_dbname"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接是否成功 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 读取转换后的csv文件 $csv_data = array_map('str_getcsv', file('your_csv_file.csv')); // 插入数据 foreach ($csv_data as $data) { $column1 = $data[0]; $column2 = $data[1]; $column3 = $data[2]; // 省略id列 $sql = "INSERT INTO your_table_name (column1, column2, column3) VALUES ('$column1', '$column2', '$column3')"; if ($conn->query($sql) === TRUE) { echo "新记录插入成功"; } else { echo "Error: " . $sql . "<br>" . $conn->error; } } // 关闭连接 $conn->close(); ``` 在上面的代码,我们首先读取了转换后的csv文件,并且使用foreach循环将每一行数据插入MySQL。在插入数据时,我们省略了id列,由MySQL自动生成。注意,在实际使用时,需要根据自己的表结构和需要插入的字段来修改代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值