Django如何新增数据库中的表(2023年最新分享)
发布时间:2025-05-20 08:58:17 发布人:远客网络
一、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如何重新生成表的相关内容别忘了在本站进行查找喔。