Django表的多对一关系

1.Django的命令

1. 安装Django
   pip install django==1.11.16
   pip install django==1.11.16 -i   源
2. 创建项目
   django-admin startproject 项目名称
3. 启动项目
   cd 项目目录下  有manage.py 
   python manage.py   runserver  # 127.0.0.1:8000
   python manage.py   runserver 80  # 127.0.0.1:80
   python manage.py   runserver 0.0.0.0:80  # 0.0.0.0:80
4. 创建APP
   python manage.py startapp app名称  
5. 数据库迁移的命令
   1. python manage.py makemigrations   # 记录models的变更记录  
   2. python manage.py migrate   # 把变更记录同步到数据库中

2.Django的settings配置

1. 静态文件
   STATIC_URL = '/static/'   # 别名
   STATICFILES_DIRS = [
       os.path.join(BASE_DIR,'static'),
       os.path.join(BASE_DIR,'static1'),
   ]
   1. 数据库
   ENGINE:    mysql
   NAME:   数据库名字
   USER:    用户名
   PASSWORD: 密码   ‘’
   HOST:   IP地址  127.0.0.1  
   PORT:      3306      
   1. 注释CSRF的中间件
   可以提交POST请求
   1. TEMPLATES   模板文件
   DIRS   [os.path.join(BASE_DIR,'templates')] 
   1. INSTALLED_APPS =[
   'app01'   或者  ‘app01.apps.App01Config’

3.get和post

1. get   ——获取一个页面
   浏览器地址栏中输入地址,回车  
   a标签 
   form表单默认发送get请求  
   携带参数:127.0.0.1:8000/edit_publisher/?pk=1
   request.GET   {} 
   1. post  ——提交数据
   form表单指定method=‘post’ 
   request.POST

4.使用mysql数据库的流程

1. 创建一个mysql数据库
2. 在settings中配置:
       DATABASES = {
           'default': {
               'ENGINE': 'django.db.backends.mysql',
               'NAME': 'bookmanager',
               'HOST': '127.0.0.1',
               'PORT': 3306,
               'USER': 'root',
               'PASSWORD': '',
       
           }
       }
3. 告诉Django使用pymysql模块连接mysql数据库
   在与settings同级目录下__init__.py中写:
       import pymysql
       pymysql.install_as_MySQLdb()
4. 在app下的models中写类(继承models.Model)
       class Publisher(models.Model):  # app01_publisher
           pid = models.AutoField(primary_key=True)  # pid 主键
           name = models.CharField(max_length=32, unique=True) # 出版社名称 varcahr(32)
5. 执行数据库迁移的命令
   1. python manage.py makemigrations   # 记录models的变更记录  
   2. python manage.py migrate   # 把变更记录同步到数据库中

5.ORM操作

对应关系:

    类   ——》   表

    对象  ——》  数据行(记录)

    属性 ——》   字段

from app01 import models

增加:

    models.Publisher.objects.create(name='xx出版社')

查询:

    models.Publisher.objects.get(name='xx出版社')   ——》 一个对象

    models.Publisher.objects.filter(name='xx出版社')  ——》 一个对象列表

    models.Publisher.objects.all()  ——》 一个对象列表  所有数据的对象

删除:

    models.Publisher.objects.get(name='xx出版社') .delete()

    models.Publisher.objects.all() .delete()

修改:

    obj=models.Publisher.objects.get(name='xx出版社')

    obj.name = '新的名字'   # 在内存中做修改

    obj.save()   # 保存在数据库中

6.模板的语法

    render(request,'模板的文件名',{'new_name':'新华出版社''errr_msg':'数据已存在'})

1. 变量  
   {{ new_name  }}   ——》 新华出版社
   1. for循环
   {%  for i in 可迭代的 %}
       {{ forloop.counter }}    循环的次数
       {{ i }}
       {{ i.name }}
       {{ i.pk}}
   {% endfor %}


1.书籍的管理

书籍和出版社    多对一  

书籍的表结构

id     name    

创建外键:

    class Book(models.Model):
        title = models.CharField(max_length=32, unique=True)  # 书籍的名称
        publisher = models.ForeignKey('Publisher', on_delete=models.CASCADE)  # 关联了出版社



查询:

    

新增:



编辑:



模板语法: if判断


 

posted @ 2018-12-04 17:40  冒蓝火的加特林哒哒哒  阅读(129)  评论(0编辑  收藏  举报