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%
帮助的人:1012万
展开全部


在网上看到都是使用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和数据表就可以了。




推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式