5数据模型和数据库

一个模型就是一个描述你数据表的python对象。不用再通过SQL来操作数据库,而是使用python对象来操作数据库。

5.1rango要求

。。。一个目录下面有多个下面

。。。一个目录有名字,访问量和喜爱量

。。。一个页面有题目,URL和一定数量的视图

5.2告诉django你的数据库

在settings.py里面进行配置,添加如下代码:

DATABASE_PATH = os.path.join(PROJECT_PATH,'rango.db')

DATABASES = {

  'default':{

    'ENGINE':'django.db.backends.sqlite3',

    'NAME':DATABASE_PATH,

}

}

5.3创建数据模型

在rango/models里面定义两个类。都要继承自django.db.models.Model.这两个类代表目录和页面,代码如下:

class Catetory(models.Model):

  name = models.CharField(max_length=128,unique=True)

  def  __unicode__(self):

    return self.name

class Page(models.Model):

  category = models.ForeignKey(Category)

  title = models.CharField(max_length=128)

  url = models.URLField()

  views = models.IntegerField(default)

  def __unicode__(self):

    return self.title

5.4创建并同步数据库

创建好之后我们需要通过manage.py来同步数据库,执行下面的命令:

python manage.py syncdb

成功会显示如下图

5.5生成SQL

使用命令python manage.py sql rango

5.6django模型和django shell

5.7配置admin接口

django还有一个特点就是提供了后台管理数据库中表,同样也需要在settings.py里面配置

INSTALLED_APPS = (

  'django.contrib.auto',

  'django.contrib.contenttypes',

  'django.contrib.sessions',

  'django.contrib.sites',

  'django.contrib.messages',

  'django.contrib.staticfiles',

  'django.contrib.admin',

  'rango',

)

然后运行python manage.py syncdb

完成以上步骤之后,就会有一个django_admin_log表。然后再配置工程文件夹下面的urls.py文件,文件显示如下:

from django.conf.urls import patterns,include,url

from django.conf import settings

from django.contrib import admin

admin.autodiscover()

urlpatterns = patterns('',

  url(r'rango/',include('rango.url')),

  url(r'admin/',include(admin.site.urls)),

)

if settings.DEBUG:

  urlpatterns += patterns(

    'django.views.static',

    (r'media/(?P<path>.*)',

    'serve',

    {'document_root':settings.MEDIA_ROOT}

),

)

到这里之后,我们需要告诉django的admin应用我们新建的数据模型。所以我们需要在rango下面新建一个admin.py问价。然后添加下面的代码

from django.contrib import admin

from rango.models import Catetory,Page

admin.site.register(Category)

admin.site.register(Page)

上面的代码就是给admin接口注册数据模型。再次重启django服务器,访问http://127.0.0.1:8000/admin/,会见到下面的页面,输入你之前创建的用户名和密码

5.8新建一个通用脚本

为了避免每次修改数据模型之后,都要删除数据库,可以工程根目录下面新建下面的文件populate_rango.py,添加如下代码:

import os

def populate():
python_cat = add_cat('Python') add_page(cat=python_cat,
title="Official Python Tutorial",
url="http://docs.python.org/2/tutorial/") add_page(cat=python_cat,
title="How to Think like a Computer Scientist",
url="http://www.greenteapress.com/thinkpython/") add_page(cat=python_cat,
title="Learn Python in 10 Minutes",
url="http://www.korokithakis.net/tutorials/python/") django_cat = add_cat("Django") add_page(cat=django_cat,
title="Official Django Tutorial",
url="https://docs.djangoproject.com/en/1.5/intro/tutorial01/") add_page(cat=django_cat,
title="Django Rocks",
url="http://www.djangorocks.com/") add_page(cat=django_cat,
title="How to Tango with Django",
url="http://www.tangowithdjango.com/") frame_cat = add_cat("Other Frameworks") add_page(cat=frame_cat,
title="Bottle",
url="http://bottlepy.org/docs/dev/") add_page(cat=frame_cat,
title="Flask",
url="http://flask.pocoo.org") # Print out what we have added to the user.
for c in Category.objects.all():
for p in Page.objects.filter(category=c):
print "- {0} - {1}".format(str(c), str(p)) def add_page(cat, title, url, views=0):
p = Page.objects.get_or_create(category=cat, title=title, url=url, views=views)[0]
return p def add_cat(name):
c = Category.objects.get_or_create(name=name)[0]
return c # Start execution here!
if __name__ == '__main__':
print "Starting Rango population script..."
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'tango_with_django_project.settings')
from rango.models import Category, Page
populate()
然后使用python populate_rango.py命令执行这个文件,得到下面的结果


【翻译】How To Tango With Django 1.5.4 第五章的更多相关文章

  1. 《Django By Example》第五章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag注:大家好,我是新来的翻译, ...

  2. 【翻译】How To Tango With Django 1.5.4 第四章

    4.模板和静态媒体 这章讲解模板引擎 4.1使用模板 前面我们讲解了view和url 映射,创建出了django 的web页面,现在就要将模板混合进去 好的网站在布局上总是有许多重复的.django提 ...

  3. 【翻译】How To Tango With Django 1.5.4 第三章

    django基础 3.1测试你的配置 测试你的python版本和你的django版本是否兼容 3.2新建django工程 在dos里面进到你事先新建的code文件夹,然后在执行下列命令新建工程 c:\ ...

  4. 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...

  5. Tango with Django 1.9 中文——1.概述

    译者注:英文书地址https://leanpub.com/tangowithdjango19/,作者为Leif Azzopardi 和 David Maxwell.本文仅为尝试.学习和交流,著作权利归 ...

  6. 《Django By Example》第六章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:无他,祝大家年会都中奖!) 第六章 ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (22) -----第五章 加载实体和导航属性之延迟加载

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第五章 加载实体和导航属性 实体框架提供了非常棒的建模环境,它允许开发人员可视化地使 ...

  8. 《Introduction to Tornado》中文翻译计划——第五章:异步Web服务

    http://www.pythoner.com/294.html 本文为<Introduction to Tornado>中文翻译,将在https://github.com/alioth3 ...

  9. Gradle 1.12用户指南翻译——第四十五章. 应用程序插件

    本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

随机推荐

  1. 每天一个linux命令---mount

    查询挂载服务的信息,使用挂载mount命令: [wapmail@app2linux04 monitor]$ mount |grep 172.16.182.146 type nfs (ro,udp,no ...

  2. JS学习(二)

    1 数组对象 作用是:使用单独的变量名来存储一系列的值. 1.1 新建数组: var mycars = new Array() mycars[0] = "Saab" mycars[ ...

  3. 51Nod 1002 数字三角形 Label:水水水 && 非学习区警告

    一个高度为N的由正整数组成的三角形,从上走到下,求经过的数字和的最大值. 每次只能走到下一层相邻的数上,例如从第3层的6向下走,只能走到第4层的2或9上.      5   8 4  3 6 9 7 ...

  4. js正则表达式实例(汇总)

    来源:如何用JAVASCRIPT 正则表达式取出字符串最后一组数字,谢谢  如  30CAC0040 取出40  3SFASDF92 取出92  正则如下://d+$/g   统一空格个数  来源:正 ...

  5. BZOJ4519: [Cqoi2016]不同的最小割

    Description 学过图论的同学都知道最小割的概念:对于一个图,某个对图中结点的划分将图中所有结点分成 两个部分,如果结点s,t不在同一个部分中,则称这个划分是关于s,t的割.对于带权图来说,将 ...

  6. jQuery 基本过滤选择器注意点

    $(".add_shuxing_ul > li:first")  选择class为add_shuxing_ul 的子级li元素的第一个li $(".add_shux ...

  7. ArcGIS 设置地图显示范围大小(全屏显示)

    Arcmap的FullExtent默认是地图加载的时候的extent.其实这个fullExtent是可以设置的. 打开ArcMap,选择左边图例的Layers ,右键点击,选择“Properties. ...

  8. 李洪强iOS面试题之-iOS选择题

    1.及时聊天app不会采用的网络传输方式是 DA UDP B TCP C Http D FTP 2.下列技术不属于多线程的是 AA Block B NSThread C NSOperation D G ...

  9. IO流,File类的测试........课堂加总结

    package liu0926; import java.io.File; import java.io.IOException; public class Text01 { public stati ...

  10. 32位的Win7系统下安装64位的Sql Sever?

    来自:http://zhidao.baidu.com/link?url=nQBoaLgoOyYCUdI7V4WZCMlTW3tKscdkOnLTIvlYtPpwoVhQkSahq44HeofBfzFT ...