Django初级手册1-项目和应用的创建与简单的数据库操作
创建项目
django-admin.py startproject mysite
1. 目录结构
mysite/ #项目的名称
manage.py #可通过命令和项目进行交互的文件
mysite/ #项目的实际文件夹
__init__.py #空文件,告诉python这个目录是个python包
settings.py #该项目的配置文件
urls.py #项目的URL声明,dispatch文件
wsgi.py #项目wscgi的一个入口
2. 启动开发机
只用于开发环境,不能用于生产环境!
开发环境支持热启动
python manage.py runserver #default 8000
#如果主机想访问虚拟机需要指定IP和端口
python manage.py runserver 0.0.0.0:8000
3. 数据库
需求MySQLdb
pip2.7 install mysql-python -i http://pypi.douban.com/simple
settings.py文件中进行设置
#mysql的数据库必须提前建好
DATABASES = {
'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
'ENGINE': 'django.db.backends.mysql',
'NAME': 'test',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
#修改时区
#TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'
#默认apps
INSTALLED_APPS = (
'django.contrib.admin', #管理页面
'django.contrib.auth', #权限系统
'django.contrib.contenttypes', #内容框架
'django.contrib.sessions', #回话框架
'django.contrib.messages', #消息框架
'django.contrib.staticfiles', #管理静态内容框架
)
#此命令会安装上述的app,并生成对应的表,在此建立系统管理员帐号和密码
python manage.py syncdb
创建模型
app完成某个特定的功能,诸如微博系统,公共记录数据库亦或是一个简单的投票程序。
project是若干配置文件与许多app组成的特殊网站。
project可以包含很多app,app也可用于多个project。
python manage.py startapp polls
这会生成
polls/
__init__.py
admin.py
models.py
tests.py
views.py
首先应该定义模型。
模型是关于数据的独立、限定的资源。它包括要存储的数据的必要的字段和行为。
Django遵循DRY原则,即Don't repeat youself——每一个独立的概念或数据都存储在一个地方,并且存储一份。
定义所有的模型,关于投票,创建投票和选择两个模型,投票包括一个问题和一个发起日期,选择包括选择的内容和投票计数。每一个选择应该关联一个投票。
from django.db import models
class Poll(models.Model):
question = models.CharField(max_length=200)
pub_date = models.DateTimeField('date published')
class Choice(models.Model):
poll = models.ForeignKey(Poll)
choice_text = models.CharField(max_length=200)
votes = models.IntegerField(default=0)
每个模型对应一个类,每个类继承自models.Model,每个类对应一张表。
每个类成员对应该表的列,并且有自己的类型。有些参数是必须的例如max_length,它不只是数据库的模式,还包括页面的验证。而整数类型的默认值是可选的。
最后类之间的关系用外键来描述。该处需要注意的是,poll会自动处理为poll_id加到
激活模型
首先应该在settings.py中添加该应用。
INSTALL_APPS = (
...
...
'polls',
)
然后键入命令,观察models生成的SQL语句。
python manage.py sql polls
这里有一些额外的命令可以观察实际的构成。
python manage.py validate #检查错误,尤其是构建apps的model后检查,再运行syncdb之前
python manage.py sqlcustom polls #输出应用定义的custom sql statement
python manage.py sqlclear polls #输出应用中有必要DROP TABLE的语句
python manage.py sqlindexes polls
python manage.py sqlall polls #输出sql sqlcustom sqlindexes的集合
然后要实际运行这些语句,在数据库中实际建立他们。该语句只用于初次创建时
python manage.py syncdb
调用API来工作
#进入互动界面
python manage.py shell
>>> from polls.models import Poll, Choice
#显示所有实例
>>> Poll.objects.all()
[]
>>> from django.utils import timezone
#创建一个对象
>>> p = Poll(question="What's new?", pub_date=timezone.now())
#存入数据库
>>> p.save()
#可使用p.question等修改,查看类成员函数,修改后再次save即可
>>> Poll.objects.all()
[<Poll: Poll object>] #这是由于__unicode__没有设置的结果,
class Poll(models.Model):
# ...
def __unicode__(self): # Python 3: def __str__(self):
return self.question
#这样即可输出
>>> Poll.objects.all()
[<Poll: What's new?>]
#查找数据库,filter(类成员名称后双下划线,可以加入各种比较)
#get可直接用来查找,其中pk可用来查找主键,PrivateKey
>>> Poll.objects.filter(question__startswith='What')
[<Poll: What's up?>]
>>> current_year = timezone.now().year
>>> Poll.objects.get(pub_date__year=current_year)
<Poll: What's up?>
因为Poll是Choice的外键,所以Poll有如下的成员函数
>>> p.choice_set.all()
[]
>>> c = p.choice_set.create(choice_text='Just hacking again', votes=0)
>>> p.choice_set.all()
[<Choice: Not much>, <Choice: The sky>, <Choice: Just hacking again>]
>>> p.choice_set.count()
3
# Choice也有如下的成员变量
>>> c.poll
<Poll: What's up?>
#删除某个记录
>>> c = p.choice_set.filter(choice_text__startswith='Just hacking')
>>> c.delete()
Django初级手册1-项目和应用的创建与简单的数据库操作的更多相关文章
- django之三剑客、静态文件配置、请求响应对象、数据库操作
三剑客 from django.shortcuts import render,HttpResponse,redirect HttpResponse # 返回字符串 render(response, ...
- Django初级手册3-视图层与URL配置
设计哲学 在Django中一个视图有指定函数和指定模版组成.对于某些特定的应用应该分成若干视图.例如博客系统 Blog主页面 详细页面入口 基于年的页面展示 基于月的页面展示 基于天的页面展示 评论行 ...
- Django初级手册2-管理界面的使用及定制
管理界面的使用 管理界面的URL,帐号和密码在第一次输入syncdb时建立 http://127.0.0.1:8000/admin/ 将app加入管理界面 编辑polls/admin.py from ...
- Django初级手册6-静态文件
用Django加载外部文件 在Django中iamges,JS或者CSS通称为static文件 定制APP的外观 一般放在应用目录下的static/polls/目录下,下为polls/static/p ...
- Django初级手册5-自动化测试
什么是自动化测试 每次更新完系统后,可自动进行测试,而不是手工从头测试一遍: 从长远和全局的角度看,测试能节约我们的时间: 测试是一种积极的行为,它能预防问题,而不仅仅是识别问题: 测试有助于代码美观 ...
- Django初级手册4-表单与通用视图
表单的编写 1. detail.html模版的编写 <h1>{{ poll.question }}</h1> {% if error_message %}<p>&l ...
- Django简单的数据库操作
当然,本篇的前提是你已经配置好了相关的环境,这里就不详细介绍. 一. 在settings.py文件中设置数据库属性. 如下: DATABASES = { 'default': { 'ENGINE': ...
- Django学习(一)---基本配置及创建项目、应用
安装:在Django官网下载最新版Django然后通过pip安装即可 一.创建项目 进入文件夹,打开cmd窗口,输入django-admin startproject myblog(项目名) 二.创建 ...
- Python Django CMDB项目实战之-3创建form表单,并在前端页面上展示
基于之前的项目代码 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页.index页.文章页面 Python Django CMDB项目实战之-2创建APP. ...
随机推荐
- win10 与linux mint双系统 只能进入mint而无法进入windows的解决方案
新购买了一块ssd,和以前的hdd硬盘一起装双系统:win10和mint ssd:win10 sdb1 sdb2 sdb3 sda2 hdd: mint sda1 ...
- 配置Mac漂亮的Shell--Iterm2+OhMyZSH+Agnoster
安装包管理器 首先当然是解决包管理的问题,Mac下面是Homebrew的天下了 /usr/bin/ruby -e "$(curl -fsSL https://raw.githubuserco ...
- JPEG图片扩展信息读取与修改
extends:http://www.2cto.com/kf/201405/303813.html 读写均是键值对的方式,需要注意的是值的类型需要严格按照api定义格式. 支持读写节点为: 1.TAG ...
- Android - dhroid 开发框架
extends:http://www.eoeandroid.com/thread-326973-1-1.html 开源中国地址:http://www.oschina.net/p/dhroid 开源项目 ...
- dinner vs supper
用dinner还是supper? 据我唯一认识一个美国人……讲,至少在美国他们用dinner,supper也许在英国更常用些. 他在小时候都没听说过supper这个词…… 另外,have dinner ...
- Razon模板
转:http://www.cnblogs.com/huangxincheng/p/3644313.html 随笔- 119 文章- 0 评论- 2039 抛弃NVelocity,来玩玩Razor ...
- yii---对数组进行分页
很多时候,我们会对多个数据进行分页处理,例如我最近开发的一个功能,系统消息,系统消息的来源是多个表,而且多个表之间的数据没有任何关联,这个时候,需要对多个表进行查询,查询返回的数据进行分页,而且采用的 ...
- BAT等大厂已开源的70个实用工具盘点(附下载地址)
前面的一篇文章<微软.谷歌.亚马逊.Facebook等硅谷大厂91个开源软件盘点(附下载地址)>列举了国外8个互联网公司(包括微软.Google.亚马逊.IBM.Facebook.Twit ...
- 专访知乎张伟:RFC技术评审机制如何助力知乎实现工程文化落地
2017年5月20-21日,MPD工作坊·上海站将于上海徐汇区光大会展中心举办,本届MPD工作坊请到了知乎工程高级总监张伟进行主题为<工程师文化落地6项指南>的3小时深度分享.在工作坊举办 ...
- 专访msup创始人兼CEO刘付强:追求卓越是数据时代下企业和个人的生存之道
近些年,"信息化带动工业化"策略的深入人心,这为信息技术本身开辟了一个更加广阔的应用天地,在这样的大环境下国内IT培训市场得了飞速发展.那么在云计算.大数据时代,如何让企业的IT团 ...