您当前的位置:首页 > 互联网教程

Django如何新增数据库中的表(2023年最新分享)

发布时间:2025-05-20 08:58:17    发布人:远客网络

Django如何新增数据库中的表(2023年最新分享)

一、Django如何新增数据库中的表(2023年最新分享)

导读:本篇文章首席CTO笔记来给大家介绍有关Django如何新增数据库中的表的相关内容,希望对大家有所帮助,一起来看看吧。

这个做法,是从新建数据库开始的,对于新建数据库DJANGO会自己在表名前加一个前缀,所以跟你自己建立的表是不一样的。不信看下数据库中的表。

至于怎么用现有数据库表,可以自己查下,DJANGO连接现有表的操作步骤,

python编程--django框架,想要添加一个表进到数据库里

代码部分:

????name?=?models.CharField(max_length=30)

????grade?=?models.IntegerField()

Django里面,管理数据库和sqlarchemy类似,也是通过orm框架来实现的。所有的数据库的建立,都是在model.py里面通过类来实现的。

a.先定义一个类,继承models.Model,然后根据需求定义参数,这些参数的类型和变量后面会进一步阐述

username?=?models.CharField(max_length=32)

password?=?models.CharField(max_length=64)

‘django.contrib.contenttypes‘,

‘django.contrib.staticfiles‘,

c.执行命令。第一条命令会生成一个初始化文件,第二个命令会生成对应的表

python?manage.py??makemigrations

这样,就在PyCharm自带的sqlite数据库里面成功的生成了一个app01_UserInfo的表。这个表默认会有一个自增的id作为主键,另外两个字段是我们通过类创建的。

d.如果希望使用mysql,因为Django默认使用了MySqldb模块,这个在3.0版本里面不存在,会直接报错。我们需要改为pymysql的模块,方法如下:

在project同名文件夹下的__init__文件中添加如下代码即可:

获取所有结果,获取到的结果是一个QuerySet的类似列表的对象,每一个元素本身又是一个对象,包括了id,name,password等属性。

obj?=?models.UserInfo.objects.all()

QuerySet[UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject]

可以通过filter进行过滤,相当于sql的where语句,因为结果也是QuerySet,因此需要再使用first()获取第一个值

obj?=?models.UserInfo.objects.filter(id=nid).first()

models.UserInfo.objects.create(username=u,password=p,user_group_id=3)

删除,可以在filter的基础上进行删除

models.UserInfo.objects.filter(id=nid).delete()

models.UserInfo.objects.filter(id=nid).update(username=u,password=p)

obj=models.UserInfo.objects.filter(id=nid)

有两种方法:1)save通过创建模型类对象,执行对象的save()方法保存到数据库中。fromdatetimeimportdatebook=BookInfo(btitle=西游记,bpub_date=date(1988,1,1),bread=10,bcomment=10)book.save()hero=HeroInfo(hname=孙悟空,hgender=0,hbook=book)hero.save()hero2=HeroInfo(hname=猪八戒,hgender=0,hbook_id=book.id)hero2.save()2)create通过模型类.objects.create()保存。HeroInfo.objects.create(hname=沙悟净,hgender=0,hbook=book)HeroInfo:沙悟净在黑马程序员社区的技术交流当中,还有删除,改懂,查询的操作全部方法。

catcher:mysite?catcher$?python?manage.py?makemigrations?books

????-?Add?field?publisher?to?book

catcher:mysite?catcher$?python?manage.py?sqlmigrate?books?0001

CREATE?TABLE?"books_author"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"first_name"?varchar(30)?NOT?NULL,?"last_name"?varchar(40)?NOT?NULL,?"email"?varchar(254)?NOT?NULL);

CREATE?TABLE?"books_book"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"title"?varchar(100)?NOT?NULL,?"publication_date"?date?NOT?NULL);

CREATE?TABLE?"books_book_authors"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"book_id"?integer?NOT?NULL?REFERENCES?"books_book"?("id"),?"author_id"?integer?NOT?NULL?REFERENCES?"books_author"?("id"));

CREATE?TABLE?"books_publisher"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"name"?varchar(30)?NOT?NULL,?"address"?varchar(50)?NOT?NULL,?"city"?varchar(60)?NOT?NULL,?"state_province"?varchar(30)?NOT?NULL,?"country"?varchar(50)?NOT?NULL,?"website"?varchar(200)?NOT?NULL);

--?Add?field?publisher?to?book

ALTER?TABLE?"books_book"?RENAME?TO?"books_book__old";

CREATE?TABLE?"books_book"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"title"?varchar(100)?NOT?NULL,?"publication_date"?date?NOT?NULL,?"publisher_id"?integer?NOT?NULL?REFERENCES?"books_publisher"?("id"));

INSERT?INTO?"books_book"?("publication_date",?"publisher_id",?"id",?"title")?SELECT?"publication_date",?NULL,?"id",?"title"?FROM?"books_book__old";

CREATE?INDEX?"books_book_2604cbea"?ON?"books_book"?("publisher_id");

catcher:mysite?catcher$?sudo?python?manage.py?migratePassword:Operations?to?perform:??Apply?all?migrations:?admin,?contenttypes,?books,?auth,?sessionsRunning?migrations:??Rendering?model?states...?DONE??Applying?contenttypes.0001_initial...?OK??Applying?auth.0001_initial...?OK??Applying?admin.0001_initial...?OK??Applying?admin.0002_logentry_remove_auto_add...?OK??Applying?contenttypes.0002_remove_content_type_name...?OK??Applying?auth.0002_alter_permission_name_max_length...?OK??Applying?auth.0003_alter_user_email_max_length...?OK??Applying?auth.0004_alter_user_username_opts...?OK??Applying?auth.0005_alter_user_last_login_null...?OK??Applying?auth.0006_require_contenttypes_0002...?OK??Applying?auth.0007_alter_validators_add_error_messages...?OK??Applying?books.0001_initial...?OK??Applying?sessions.0001_initial...?OKcatcher:mysite?catcher$

结语:以上就是首席CTO笔记为大家介绍的关于Django如何新增数据库中的表的全部内容了,希望对大家有所帮助,如果你还想了解更多这方面的信息,记得收藏关注本站。

二、Django为什么创建数据库出错(django操作已有数据库)

今天给各位分享Django为什么创建数据库出错的知识,其中也会对django操作已有数据库进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

就可以通过127.0.0.1:8000访问了

在我的workbench中可以看到生成了默认的table

接下来我们自己建立model(需要继承models.Model)

修改model让其返回name,修改views让其在页面上显示返回的结果

错误:class Topic(models.Models):

正确:class Topic(models.Model):

求教,django的数据库错误的解决方法

错误代码 1045

Access denied for user'root'@'localhost'

如果你的mysql也出现以上这种提示,

建议你逐个字看完我这篇文章再按以下方法来尝试解决问题.

这是mysql数据库很多时候出现的问题,网上流传很多解决办法.有人按照那些方法,还真可以把问题解决了;但也有很多人按那些方法解决不了问题!

而这个中原因,就是没有对症下药!!!

网上的那些方法,很多都没有明确指出是什么版本的mysql,所以导致问题者不能对症下药.

出现这个问题,通过停止/重启 mysql服务,是可以解决的,这个是最简单的办法!对于不懂得什么叫做"停止/重启mysql服务"的人来说,

这个最简单的办法就是把服务器主机进行重新启动(就是把你的电脑进行重新启动).

以上是方法A!(这个方法适合任何版本的mysql)

以下是方法B:(方法仅适用于MySQL4.0.26版本!!!(我估计,

网上也有说,就是对root进行重改密码.对于网上流传的改密码方法,也是可行的.请参考以下:

DOS下修改ROOT密码:当然后面安装PHPMYADMIN后修改密码也可以通过PHPMYADMIN修改

格式:mysqladmin-u用户名-p旧密码 password

首先在进入CMD命令行,转到MYSQL目录下的bin目录,然后键入以下命令

注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。

D:\php\MySQL\binmysqladmin-uroot password

ideacmblog回车后ROOT密码就设置为ideacmblog了

但是,请注意了,以上方法仅适用于MySQL4.0.26

版本!!!(我估计, 4.0的其他版本应该也可以的)

好了,扯了那么多,以上的两个方法都不是我本人测试过的,本人不对真实性负责!

而现在我说一下本人亲自试过的方法,以供参考:

话说今天,我的服务器所有php及使用了mysql数据库的网站,均挂掉了!无法打开,

user'root'@'localhost'(using password:YES)

一开始我也是不断搜索google(我本人不喜欢百度!),

去找寻解决的办法.看了很多,也参照执行了,事实上也是解决不了问题.后来我想到了是版本的问题,不同的mysql版本,

解决办法是不一定一样的!!记住...

(mysql-essential-5.0.22-win32)

今天一整天,那些php网站均罢工.到今晚才有时间上去服务器继续寻找方法,但仍然解决不了.

最后,我决定把mysql卸掉重新安装!

卸载很快,而且不需要重新启动计算机.

打开这个mysql-essential-5.0.22-win32.exe文件;

第二步:见到窗口弹出,并点击 Next

Change...选择你原安装mysql的目录;选择后,继续点击Next进入下一步;

安装至下一步,会提示你进行注册,选择最后一项,即跳过注册,

安装完成后,继续弹出一个窗口,提示你是不是立刻进行配置,

选择Standard Configuration.继续点击

这一步里,把上面那行的勾去掉,只在 Include

....PATH那行打勾,继续点击 Next进入下一步

在这一步,点击中间的"Ex****"那顶,

这时候,你去看看你的mysql正常了没有??

Traceback(most recent call last):

File"/root/envs/django-test/bin/django-admin", line 11, in module

sys.exit(execute_from_command_line())

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/management/__init__.py", line 354, in execute

File"/root/envs/django-test/lib/python3.5/site-packages/django/__init__.py", line 18, in setup

from django.utils.log import configure_logging

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/log.py", line 10, in module

from django.views.debug import ExceptionReporter, get_exception_reporter_filter

File"/root/envs/django-test/lib/python3.5/site-packages/django/views/debug.py", line 10, in module

from django.http import(HttpResponse, HttpResponseServerError,

File"/root/envs/django-test/lib/python3.5/site-packages/django/http/__init__.py", line 4, in module

from django.http.response import(HttpResponse, StreamingHttpResponse,

File"/root/envs/django-test/lib/python3.5/site-packages/django/http/response.py", line 13, in module

from django.core.serializers.json import DjangoJSONEncoder

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/serializers/__init__.py", line 23, in module

from django.core.serializers.base import SerializerDoesNotExist

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/serializers/base.py", line 6, in module

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/__init__.py", line 6, in module

from django.db.models.query import Q, QuerySet, Prefetch# NOQA

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/query.py", line 13, in module

from django.db.models.fields import AutoField, Empty

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/fields/__init__.py", line 18, in module

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/__init__.py", line 6, in module

from django.forms.fields import*# NOQA

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/fields.py", line 18, in module

from django.forms.utils import from_current_timezone, to_current_timezone

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/utils.py", line 15, in module

from django.utils.html import format_html, format_html_join, escape

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/html.py", line 16, in module

from.html_parser import HTMLParser, HTMLParseError

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/html_parser.py", line 12, in module

HTMLParseError= _html_parser.HTMLParseError

AttributeError: module'html.parser' has no attribute'HTMLParseError'

(django-test) root@localhost:~/source/djangotest# django-admin startproject superlists

Traceback(most recent call last):

File"/root/envs/django-test/bin/django-admin", line 11, in module

sys.exit(execute_from_command_line())

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/management/__init__.py", line 354, in execute

File"/root/envs/django-test/lib/python3.5/site-packages/django/__init__.py", line 18, in setup

from django.utils.log import configure_logging

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/log.py", line 10, in module

from django.views.debug import ExceptionReporter, get_exception_reporter_filter

File"/root/envs/django-test/lib/python3.5/site-packages/django/views/debug.py", line 10, in module

from django.http import(HttpResponse, HttpResponseServerError,

File"/root/envs/django-test/lib/python3.5/site-packages/django/http/__init__.py", line 4, in module

from django.http.response import(HttpResponse, StreamingHttpResponse,

File"/root/envs/django-test/lib/python3.5/site-packages/django/http/response.py", line 13, in module

from django.core.serializers.json import DjangoJSONEncoder

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/serializers/__init__.py", line 23, in module

from django.core.serializers.base import SerializerDoesNotExist

File"/root/envs/django-test/lib/python3.5/site-packages/django/core/serializers/base.py", line 6, in module

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/__init__.py", line 6, in module

from django.db.models.query import Q, QuerySet, Prefetch# NOQA

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/query.py", line 13, in module

from django.db.models.fields import AutoField, Empty

File"/root/envs/django-test/lib/python3.5/site-packages/django/db/models/fields/__init__.py", line 18, in module

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/__init__.py", line 6, in module

from django.forms.fields import*# NOQA

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/fields.py", line 18, in module

from django.forms.utils import from_current_timezone, to_current_timezone

File"/root/envs/django-test/lib/python3.5/site-packages/django/forms/utils.py", line 15, in module

from django.utils.html import format_html, format_html_join, escape

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/html.py", line 16, in module

from.html_parser import HTMLParser, HTMLParseError

File"/root/envs/django-test/lib/python3.5/site-packages/django/utils/html_parser.py", line 12, in module

HTMLParseError= _html_parser.HTMLParseError

AttributeError: module'html.parser' has no attribute'HTMLParseError'12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576771234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677

三、django如何重新生成表(django创建表)

导读:本篇文章首席CTO笔记来给大家介绍有关django如何重新生成表的相关内容,希望对大家有所帮助,一起来看看吧。

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

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?manage.py?makemigration

会在数据库中生成名称为show_sciencenews的数据表。show为应用名称,此处我的应用名称为show。可以看到Django创建表的命名规则:应用名_模型名。

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

catcher:mysite?catcher$?python?manage.py?makemigrations?books

????-?Add?field?publisher?to?book

catcher:mysite?catcher$?python?manage.py?sqlmigrate?books?0001

CREATE?TABLE?"books_author"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"first_name"?varchar(30)?NOT?NULL,?"last_name"?varchar(40)?NOT?NULL,?"email"?varchar(254)?NOT?NULL);

CREATE?TABLE?"books_book"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"title"?varchar(100)?NOT?NULL,?"publication_date"?date?NOT?NULL);

CREATE?TABLE?"books_book_authors"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"book_id"?integer?NOT?NULL?REFERENCES?"books_book"?("id"),?"author_id"?integer?NOT?NULL?REFERENCES?"books_author"?("id"));

CREATE?TABLE?"books_publisher"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"name"?varchar(30)?NOT?NULL,?"address"?varchar(50)?NOT?NULL,?"city"?varchar(60)?NOT?NULL,?"state_province"?varchar(30)?NOT?NULL,?"country"?varchar(50)?NOT?NULL,?"website"?varchar(200)?NOT?NULL);

--?Add?field?publisher?to?book

ALTER?TABLE?"books_book"?RENAME?TO?"books_book__old";

CREATE?TABLE?"books_book"?("id"?integer?NOT?NULL?PRIMARY?KEY?AUTOINCREMENT,?"title"?varchar(100)?NOT?NULL,?"publication_date"?date?NOT?NULL,?"publisher_id"?integer?NOT?NULL?REFERENCES?"books_publisher"?("id"));

INSERT?INTO?"books_book"?("publication_date",?"publisher_id",?"id",?"title")?SELECT?"publication_date",?NULL,?"id",?"title"?FROM?"books_book__old";

CREATE?INDEX?"books_book_2604cbea"?ON?"books_book"?("publisher_id");

catcher:mysite?catcher$?sudo?python?manage.py?migratePassword:Operations?to?perform:??Apply?all?migrations:?admin,?contenttypes,?books,?auth,?sessionsRunning?migrations:??Rendering?model?states...?DONE??Applying?contenttypes.0001_initial...?OK??Applying?auth.0001_initial...?OK??Applying?admin.0001_initial...?OK??Applying?admin.0002_logentry_remove_auto_add...?OK??Applying?contenttypes.0002_remove_content_type_name...?OK??Applying?auth.0002_alter_permission_name_max_length...?OK??Applying?auth.0003_alter_user_email_max_length...?OK??Applying?auth.0004_alter_user_username_opts...?OK??Applying?auth.0005_alter_user_last_login_null...?OK??Applying?auth.0006_require_contenttypes_0002...?OK??Applying?auth.0007_alter_validators_add_error_messages...?OK??Applying?books.0001_initial...?OK??Applying?sessions.0001_initial...?OKcatcher:mysite?catcher$

django1.8更改了model后要怎样重建数据库

#?如果你说用的是pycharm编译器的话:

#?如果你说用的是pycharm编译器的话:

使用?ctrl+alt+r?进入?manage界面

然后输入?makemigrations?[appname]?创建数据库引导文件

然后使用?migrate?[appname]?来把model变化同步到数据库

#?[appname]?指你当前model所在的app,如果不指定appname?;则编译全部app

#?如果不是pycharm编译器的话,请再追问

Django里面,管理数据库和sqlarchemy类似,也是通过orm框架来实现的。所有的数据库的建立,都是在model.py里面通过类来实现的。

a.先定义一个类,继承models.Model,然后根据需求定义参数,这些参数的类型和变量后面会进一步阐述

username?=?models.CharField(max_length=32)

password?=?models.CharField(max_length=64)

‘django.contrib.contenttypes‘,

‘django.contrib.staticfiles‘,

c.执行命令。第一条命令会生成一个初始化文件,第二个命令会生成对应的表

python?manage.py??makemigrations

这样,就在PyCharm自带的sqlite数据库里面成功的生成了一个app01_UserInfo的表。这个表默认会有一个自增的id作为主键,另外两个字段是我们通过类创建的。

d.如果希望使用mysql,因为Django默认使用了MySqldb模块,这个在3.0版本里面不存在,会直接报错。我们需要改为pymysql的模块,方法如下:

在project同名文件夹下的__init__文件中添加如下代码即可:

获取所有结果,获取到的结果是一个QuerySet的类似列表的对象,每一个元素本身又是一个对象,包括了id,name,password等属性。

obj?=?models.UserInfo.objects.all()

QuerySet[UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject,UserInfo:UserInfoobject]

可以通过filter进行过滤,相当于sql的where语句,因为结果也是QuerySet,因此需要再使用first()获取第一个值

obj?=?models.UserInfo.objects.filter(id=nid).first()

models.UserInfo.objects.create(username=u,password=p,user_group_id=3)

删除,可以在filter的基础上进行删除

models.UserInfo.objects.filter(id=nid).delete()

models.UserInfo.objects.filter(id=nid).update(username=u,password=p)

obj=models.UserInfo.objects.filter(id=nid)

请确认只删除了表,没有删除scheme

最简单的办法是。为数据库的表建立一个model。具体做法是这样子。

1.在settings.py里设置数据库连接方式。连接错误后面都没有办法

2.在models设置一个数据库表的对应数据结构,通常叫关系对象模型,所以叫model,它就是一个类。你可以用django-admin.py...probe,似乎是这个命令,就是一个数据库的探测命令,可以根据表,自动生成model的代码。当然如果你先写了model的代码就可以用syncdb命令生成数据库的表

3.在urls.py里设置一个URL的path,当浏览器访问这个path时就可以打开对应的view中的函数

4.1result=modelclass.objects.all()这个命令可以取出所有的记录

4.2然后你可以直接将结果传递给模板。由模板显示。这是最合理的办法

4.3在模板里{%forcolsinresult%}

大约就是这样子。可能说的太粗。你对着教程看就知道了。

结语:以上就是首席CTO笔记为大家整理的关于django如何重新生成表的全部内容了,感谢您花时间阅读本站内容,希望对您有所帮助,更多关于django如何重新生成表的相关内容别忘了在本站进行查找喔。