Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python “Django”;违反主键约束“;但是,主键是BigAutoField_Python_Sql Server_Django_Python 3.x_Orm - Fatal编程技术网

Python “Django”;违反主键约束“;但是,主键是BigAutoField

Python “Django”;违反主键约束“;但是,主键是BigAutoField,python,sql-server,django,python-3.x,orm,Python,Sql Server,Django,Python 3.x,Orm,我有一个名为ReadUnit的表 class ReadUnits(models.Model): ReadID = models.BigAutoField(primary_key=True, unique=True, null=False) ReadDate = models.DateField(null=False) settings.py具有以下用于访问数据库的设置: DATABASES = { 'default': { 'NAME': 'MyProj

我有一个名为ReadUnit的表

class ReadUnits(models.Model):
    ReadID = models.BigAutoField(primary_key=True, unique=True, null=False)
    ReadDate = models.DateField(null=False)
settings.py具有以下用于访问数据库的设置:

DATABASES = {
    'default': {
        'NAME': 'MyProjectDB',
        'ENGINE': 'sqlserver_ado',
        'HOST': '127.0.0.1',
        'USER': 'sa',
        'PASSWORD': 'pass',
        'OPTIONS': {
            'provider': 'SQLOLEDB'
        },
    }
}
这个项目在几个月内运作良好。每天向表中添加30~40条记录。最近,我有时会遇到“违反主键约束”错误。将记录插入此表的代码非常简单:

ReadUnits(ReadDate=str(datetime.datetime.now().strftime("%Y-%m-%d"))).save()

现在它变得非常棒,因为每次代码运行时,都会发生错误。因此,这些天没有任何记录保存在DB中。

这不是Django、ORM或数据库连接器的问题。SQL Server 2012和SQL Server 2014存在一个错误,即当实例处于内存压力下,并且多个并发连接从同一序列对象请求序列值时,可能会生成重复的序列值。 Microsoft已发布解决此问题的修复程序:


您能在数据库中显示您现在有什么id吗?例如1或2个示例如果已经定义了DateField???,那么为什么要使用str(),可以使用datetime.now()。day@ExpratorReadID的最大值现在是36227。重复的键值类似于14380、14381、14382等。。。在多次插入失败后,该值会增加。您是对的。但这不是问题所在@穆纳达乌阿迪