Duplicate entry for key 1的解决方法

这个程序昨天运行的时候还好好的,一切顺利。

可是今天再运行却出现了这个异常提示:com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Duplicate entry 002 for key 1

 

源程序如下:

 

import java.sql.*;
public class xhy
{
 public static void main(String args[])
 {
  ResultSet rs;
  try{ Class.forName("com.mysql.jdbc.Driver");
  }
  catch(ClassNotFoundException e)
  {
   System.out.println(" "+e);
  }
  try{
   Connection con=DriverManager.getConnection("jdbc:mysql://127.0.0.1/xhy","root","123456");
            Statement sql=con.createStatement();
           // String s="INSERT INTO book VALUES('002','JAVA','清华出版社',43.2)";
            String s1="INSERT INTO book VALUES('003','JSP','中山大学出版社',28.0)";
            sql.executeUpdate(s1);
            rs=sql.executeQuery("select BookId from book");
            while(rs.next())
            {
             String id=rs.getString(1);
             System.out.println("学号:"+id);
             
            }
            con.close();
   }
  catch(SQLException e)
  {
   System.out.println(e);
  }
  
 }

}

问题分析:这个问题提示了我们已经重复导入数据到数据库,这是不允许的。

 解决这个问题的方法就是用“//”注释掉已经添加的数据,然后,写入新的不一样的语句,运行则可。如绿色背景所示

以上提供一种这类问题的解决思路,仅作一个例子。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值