django自动生成model模型映射表时候发生异常

(web_01)D:\inspur_01\web_01\Scripts\web_01>pythonmanage.pymakemigrationsMigrationsfor... (web_01) D:\inspur_01\web_01\Scripts\web_01>python manage.py makemigrations
Migrations for 'shop':
  shop\migrations\0001_initial.py
    - Create model Employee

(web_01) D:\inspur_01\web_01\Scripts\web_01>python manage.py migrate
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, sessions, shop
Running migrations:
  Applying contenttypes.0001_initial...Traceback (most recent call last):
  File "D:\inspur_01\web_01\lib\site-packages\django\db\backends\utils.py", line 62, in execute
..........
    return self.cursor.execute(query, self._param_generator(params))
django.db.utils.DatabaseError: ORA-00955: name is already used by an existing object
展开
 我来答
玖玖绽放2172
2019-04-22 · TA获得超过4707个赞
知道大有可为答主
回答量:1.1万
采纳率:74%
帮助的人:1010万
展开全部


在网上看到都是使用Django的models和makemigration,migrate命令来创建新表,并使用。可是我的数据已经存在了已经创建好,并且已经存储有数据了,不能再重新创建新表了。了解Django的表明和models名称的映射关系就可以让Django使用已经存在的表。

假如在Django存在models如下:

[python] view plain copy

  • from django.db import models

  • # Create your models here.

  • class Sciencenews(models.Model):

  • id = models.CharField(max_length=36,primary_key=True)

  • first_module = models.CharField(max_length=30,default="News")

  • second_module = models.CharField(max_length=30,default="Latest News")

  • title = models.CharField(max_length=300)

  • author = models.CharField(max_length=60,null=True)

  • publish_date = models.CharField(max_length=35,null=True)

  • content = models.TextField(null=True)

  • crawl_date = models.CharField(max_length=35,null=True)

  • from_url = models.CharField(max_length=350,null=True)

  • 执行数据迁移命令:
  • [python] view plain copy

  • python manage.py makemigration

  • python manage.py migrate

  • 会在数据库中生成名称为show_sciencenews的数据表。show为应用名称,此处我的应用名称为show。可以看到Django创建表的命名规则:应用名_模型名。
  • 我的存储爬取到的数据的表格名称原来为science_news,想要Django使用它,而不是创建新的表,只需要把的它的名称改为:应用名_要与该表映射的models名称,在此处我改为show_sciencenews。然后使用如上的数据迁移命令,这时可能会提示数据表已经存在的错误,不用理会,models已经和数据表映射上了。接下来只需要正常使用models和数据表就可以了。




光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式