本文摘自php中文网,作者巴扎黑,侵删。
下面小编就为大家带来一篇django 常用orm操作详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧Django流程:
1 创建Django项目 : django-admin startproject projectname
2 创建应用: : python manage.py startapp appname
3 在控制器(urls.py)创建 url 与 视图函数的映射关系(一一对应)
4 创建视图函数,完成逻辑代码
5 从数据库取出集合对象
5 把数据库变量嵌入到模板进行渲染(render方法)
6 将渲染后的html页面返回给客户端
URL:协议+域名+端口+路径
协议:http
域名:www.cnblogs.com
端口:80
路径:yuanchenqi/articles/6811632.html
数据:a=1
URL配置中的正则表达式匹配的是一个url的路径部分
TEMPALTE(模板):HTML代码+逻辑控制代码
逻辑控制语法: {{}} 渲染变量 filter : {{var|方法:参数}}
{% %} 渲染标签
{% if %}
{% for %}
{% url %}
{% url %}
自定义filter和simpletag:
(1)在app中创建templatetags模块(必须的)
(2)创建任意 .py 文件,如:my_tags.py
from django import template
register = template.Library()
@register.filter
def filter_multi(v1,v2):
return v1 * v2
(3)创建任意 .py 文件,如:my_tags.py
在使用自定义simple_tag和filter的html文件中导入之前创建的 my_tags.py :{% load my_tags %}
(4)使用simple_tag和filter:
{% load xxx %} #首行
# num=12
{{ num|filter_multi:2 }} #24
总结:
filter: 只能接受一个参数,但是可以用if等语句
simpletag: 能接受多个参数,但是不可以用if等语句
ORM:
表之表之间的关系:
一对多 外键字段一定是在子表(一对多的多的表)中 Foreign KEY
多对多 在第三张表实现,通过两个Foreign KEY
一对一 在外键字段的基础上增加唯一约束。
使用mysql方法
1更改setting文件db配置
2更改__init__文件中的驱动配置
ORM转sql的配置
settings里面配置loging
表.object.filter():得到的是一个集合对象 比如 [obj1,obj2]
表.object.get(): 得到的是一个model对象
一对多的添加记录:
# 方法1:
# Book.objects.create(id=1,title="python",publication_date="2017-03-04",price=88.8,publisher_id=1)
#方法2
p1=Publisher.objects.get(name="人大出版社")
Book.objects.create(id=2,title="python",publication_date="2017-05-04",price=98.8,publisher=p1)
在models.py文件中创建多对多关系
authors=models.ManyToManyField("Author") #多对多如果表在下方则需要加引号
相关阅读 >>
更多相关阅读请进入《Python》频道 >>

Python编程 从入门到实践 第2版
python入门书籍,非常畅销,超高好评,python官方公认好书。