Django之数据库连接与建模
Django数据库链接(这里以Mysql为例)
需要准备
- Django1.10 pip install django==1.10 -i https://pypi.tuna.tsinghua.edu.cn/simple
- PyMySQL pip install PyMySQL -i https://pypi.tuna.tsinghua.edu.cn/simple
- MySQL数据库
修改项目的settings文件
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST':'127.0.0.1', 'PORT':'3306', 'USER':'root', 'PASSWORD':'mysql', 'NAME':'django_demo', } }
接着修改项目的__init__文件(默认为空)
import pymysql pymysql.install_as_MySQLdb()
如果不更改的话就会出现以下的错误
一些其他的配置
一、概述: #静态文件交由Web服务器处理,Django本身不处理静态文件。简单的处理逻辑如下(以nginx为例): # URI请求-----> 按照Web服务器里面的配置规则先处理,以nginx为例,主要求配置在nginx. #conf里的location |---------->如果是静态文件,则由nginx直接处理 |---------->如果不是则交由Django处理,Django根据urls.py里面的规则进行匹配 # 以上是部署到Web服务器后的处理方式,为了便于开发,Django提供了在开发环境的对静态文件的处理机制,方法是这样: #1、在INSTALLED_APPS里面加入'django.contrib.staticfiles', #2、在urls.py里面加入 if settings.DEBUG: urlpatterns += patterns('', url(r'^media/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.MEDIA_ROOT }), url(r'^static/(?P<path>.*)$', 'django.views.static.serve',{'document_root':settings.STATIC_ROOT}), ) # 3、这样就可以在开发阶段直接使用静态文件了。 二、MEDIA_ROOT和MEDIA_URL #而静态文件的处理又包括STATIC和MEDIA两类,这往往容易混淆,在Django里面是这样定义的: #MEDIA:指用户上传的文件,比如在Model里面的FileFIeld,ImageField上传的文件。如果你定义 #MEDIA_ROOT=c:\temp\media,那么File=models.FileField(upload_to="abc/")#,上传的文件就会被保存到c:\temp\media\abc #eg: class blog(models.Model): Title=models.charField(max_length=64) Photo=models.ImageField(upload_to="photo") # 上传的图片就上传到c:\temp\media\photo,而在模板中要显示该文件,则在这样写 #在settings里面设置的MEDIA_ROOT必须是本地路径的绝对路径,一般是这样写: BASE_DIR= os.path.abspath(os.path.dirname(__file__)) MEDIA_ROOT=os.path.join(BASE_DIR,'media/').replace('\\','/') #MEDIA_URL是指从浏览器访问时的地址前缀,举个例子: MEDIA_ROOT=c:\temp\media\photo MEDIA_URL="/data/" #在开发阶段,media的处理由django处理: # 访问http://localhost/data/abc/a.png就是访问c:\temp\media\photo\abc\a.png # 在模板里面这样写<img src="{{MEDIA_URL}}abc/a.png"> # 在部署阶段最大的不同在于你必须让web服务器来处理media文件,因此你必须在web服务器中配置, # 以便能让web服务器能访问media文件 # 以nginx为例,可以在nginx.conf里面这样: location ~/media/{ root/temp/ break; } # 具体可以参考如何在nginx部署django。 三、STATIC_ROOT和STATIC_URL、 STATIC主要指的是如css,js,images这样文件,在settings里面可以配置STATIC_ROOT和STATIC_URL, 配置方式与MEDIA_ROOT是一样的,但是要注意 #STATIC文件一般保存在以下位置: #1、STATIC_ROOT:在settings里面设置,一般用来放一些公共的js,css,images等。 #2、app的static文件夹,在每个app所在文夹均可以建立一个static文件夹,然后当运行collectstatic时, # Django会遍历INSTALL_APPS里面所有app的static文件夹,将里面所有的文件复制到STATIC_ROOT。因此, # 如果你要建立可复用的app,那么你要将该app所需要的静态文件放在static文件夹中。 # 也就是说一个项目引用了很多app,那么这个项目所需要的css,images等静态文件是分散在各个app的static文件的,比 # 较典型的是admin应用。当你要发布时,需要将这些分散的static文件收集到一个地方就是STATIC_ROOT。 #3、STATIC文件还可以配置STATICFILES_DIRS,指定额外的静态文件存储位置。 # STATIC_URL的含义与MEDIA_URL类似。 # ---------------------------------------------------------------------------- #注意1: #为了后端的更改不会影响前端的引入,避免造成前端大量修改 STATIC_URL = '/static/' #引用名 STATICFILES_DIRS = ( os.path.join(BASE_DIR,"statics") #实际名 ,即实际文件夹的名字 ) #django对引用名和实际名进行映射,引用时,只能按照引用名来,不能按实际名去找 #<script src="/statics/jquery-3.1.1.js"></script> #------error-----不能直接用,必须用STATIC_URL = '/static/': #<script src="/static/jquery-3.1.1.js"></script> #注意2(statics文件夹写在不同的app下,静态文件的调用): STATIC_URL = '/static/' STATICFILES_DIRS=( ('hello',os.path.join(BASE_DIR,"app01","statics")) , ) #<script src="/static/hello/jquery-1.8.2.min.js"></script> #注意3: STATIC_URL = '/static/' {% load staticfiles %} # <script src={% static "jquery-1.8.2.min.js" %}></script>
接下来建立数据库(Mysql)
- win+r 打开cmd
- 连接到Mysql mysql -uroot -p
- 输入password
- 建立新的数据库 create database test character set utf8; 创建数据库设置字符集编码
- 使用新建的数据库 use test;
在PyCharm中连接数据库
- 打开Terminal控制台
- 点击窗口左侧的Database
- 添加数据库选择MySQL
- 点击Test Connection测试是否成功
- 成功后点击OK,这样数据库就连接成功了。
数据库建模
在Django中,所有的数据库都写在一个名为models.py的文件当中
from django.db import models # 出版社 class Publishers(models.Model): name = models.CharField(max_length=30, verbose_name="名称") city = models.CharField(max_length=60, verbose_name="城市") def __str__(self): return self.name # 作者 class Author(models.Model): name = models.CharField(max_length=32, verbose_name="作者") # 作者名字 gender = models.CharField(max_length=4,verbose_name="作者性别") # 作者性别 # gender = models.BooleanField(verbose_name="作者性别") def __str__(self): return self.name # 书籍 class Book(models.Model): title = models.CharField(max_length=32) # 图书名 authors = models.ManyToManyField(Author) # 多个作者 publisher = models.ForeignKey(Publishers) # 出版社名 publication_date = models.DateField(verbose_name="出版日期") #出版日期 price = models.DecimalField(max_digits=5, decimal_places=2, default=10,verbose_name="价格") def __str__(self): return self.title
接下在使用这两个命令生成迁移文件:
-
python manage.py makemigrations (生成数据库同步脚本)
-
python manage.py migrate (迁移数据)
-
将生成的数据库文件拖入Database框中
这样数据库就连接好了Application name
如果数据库结构需要做更变
- 在models.py文件中更改表的结构
- python manage.py makemigrations Application name (生成数据库同步脚本 Application name为项目中的APP名)
- python manage.py migrate (迁移数据)
- 将生成的数据库文件拖入Database框中