MySQL不插入重复数据与删除重复数据

本文介绍如何在MySQL中插入数据时避免重复插入相同数据,通过使用虚表和子查询来实现这一目标。

今天写个小程序需要用到mysql,需求就是要求插入数据,但该数据不能已存在于表中,否则就不插入。

比如我需要插入question="aaa",correctAnswer="bbb"的数据,代码如下:

1
2
3
4
5
6
7
8
INSERT  INTO  questions
(question,correctAnswer)
SELECT  'aaa' , 'bbb'  FROM  dual
where  not  exists(
SELECT  FROM  questions
where  question= 'aaa'
and  correctAnswer= 'bbb'
)
1
<span class= "span4br" ></span>

其中"dual"为虚表,用于不提供实际表名查询数据。

当然,如果已经插入了若干条重复数据,则可以这么删除:

1
2
3
4
5
6
7
8
9
10
DELETE  FROM  a USING questions  AS  a,
(
SELECT  *
FROM  questions
GROUP  BY  question, correctAnswer
HAVING  COUNT ( * ) >1
AS  b
WHERE  a.question = b.question
AND  a.correctAnswer = b.correctAnswer
AND  a.questionId > b.questionId
1
<span class= "span4br" ></span>


转载于:https://my.oschina.net/u/2260184/blog/518513

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值