在MySQL设计好数据库往往数据库中插入数据的时候,
因为主键ID默认是不赋值的,只给其他项目赋值了,相关的SQL代码是这样的
StringBuilder strSql = new StringBuilder(); strSql.Append("insert into tb_enterprise_product("); strSql.Append("enterprise_id"); strSql.Append(",datetime"); strSql.Append(",value"); strSql.Append(",product"); strSql.Append(") values("); strSql.Append("@enterprise_id"); strSql.Append(",@datetime"); strSql.Append(",@value"); strSql.Append(",@product"); strSql.Append(")"); MySqlParameter[] parameters = new MySqlParameter[] { new MySqlParameter("@enterprise_id", MySqlDbType.Int32) , new MySqlParameter("@datetime", MySqlDbType.VarChar) , new MySqlParameter("@value", MySqlDbType.VarChar) , new MySqlParameter("@product", MySqlDbType.VarChar) };
数据库的设计是这样的
可以发现因为ID是主键 所以SQL语句没有给ID赋值
那么问题来了,id是int类型,int类型如果不允许为空那么会被默认为0,所以插入第二条数据时,数据库中已经有了主键为0的数据,所以冲突了,产生了错误!
Duplicate entry '0' for key 'PRIMARY'
那么,解决办法时,把id字段设置为自增类型,相关SQL语句是:
create table t_user( id int primary key auto_increment )