django环境准备学习笔记(三)
环境准备
创建Django工程
django-admin startproject 工程名
创建 Django 超级用户:python manage.py createsuperuser
1、注释 #'django.middleware.csrf.CsrfViewMiddleware',
2、创建template模板文件夹和static静态文件夹
3、设置静态路径:STATICFILES_DIRS = (
os.path.join(BASE_DIR, 'static'),
)
4、创建app cd 工程名 python manage.py startapp APP01
5、将APP01注册到setting里
6、在app的models里面创建数据库
第一张表:
class Host(models.Model):
nid = models.AutoField(primary_key=True) #主键一般自动生成,也可以自己设定,但是需要声明primary_key
hostname = models.CharField(max_length=32,db_index=True) #db_index添加索引
ip = models.GenericIPAddressField(protocol="ipv4",db_index=True) #db_index添加索引设置字段为ip模式
port = models.IntegerField()
b = models.ForeignKey(to="Business", to_field='id') 添加外键,关联到Business的id 第二张表:
class Business(models.Model):
# id 自动创建
caption = models.CharField(max_length=32)
code = models.CharField(max_length=32,null=True,default="SA")
# fk = models.ForeignKey('Foo') 7、执行命令,创建表
python manage.py makemigrations
python manage.py migrate
创建表之后可能会修改表结构或者改表名字等,先在models里面做完修改执行命令之后会有选项,
让你为新加的列设置默认值,也可以在models里面修改的时候这样写
code = models.CharField(max_length=32,null=True,default="SA")
7.1查看表:使用Navicat Premium查看表是否建立
在admin里面创建注册表,也可以使用admin后台页面对数据库增删改查
# -*- coding: utf-8 -*-
from __future__ import unicode_literals from django.contrib import admin from app01.models import UserInfo
from app01.models import Zte
# Register your models here. class UserInfoAdmin(admin.ModelAdmin):
pass class zte(admin.ModelAdmin):
pass admin.site.register(UserInfo,UserInfoAdmin)
admin.site.register(Zte,zte)
8、在url里面加入:
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^business$', views.business), 这里一般加一个终止符,不加的话下面那一行永远不会执行
#url(r'^businessadd', admin.site.urls),
]
9、在app01的views里面加入business函数
from django.shortcuts import render
from django.shortcuts import redirect
from app01 import models
# Create your views here.
def business(request):
#从数据库获取但表单的三种方式
v=models.Business.objects.all()
#QuerySet 上面语句会得到一个QuerySet列表,列表里面是三个对象。对象有下面这些属性
# [obj(id,caption,code),obj(id,caption,code),obj(id,caption,code) ]
另一种方法
v2 = models.Business.objects.all().values('id','caption')#根据value获得了两列值
# QuerySet
# [{'id':1,'caption': '运维部'},{'id':1,'caption': '开发'},...]
v3 = models.Business.objects.all().values_list('id','caption')
# QuerySet
# [(1,运维部),(2,开发)]
return render(request,'business.html',{'v':v}) 9.1使用host调用外键字段的方法
def host(request):
v1 = models.Host.objects.all()
v2 = models.Host.objects.filter(nid__gt=0)
print v1,'-----',v2,'----'
for row in v2:
print (row.nid,row.hostname,row.ip,row.port,row.b_id,row.b.caption,row.b.id)
# return HttpResponse('112312')
# v1 = models.Business.objects.filter(host__nid__gt=0)#也可以使用大于0的方式来获取
return render(request, 'host.html', {'v1': v1}) 10、在模块路径下增加business.html文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>业务线列表(对象形式的)</h1>
<ul>
{% for row in v1 %}
<li>{{ row.id}}-{{ row.caption}}-{{ row.code }}</li>
{% endfor %}
</ul>
<h1>业务线列表(字典形式的)</h1>
<ul>
{% for row in v2 %}
<li>{{ row.id}}-{{ row.caption}}-</li>
{% endfor %}
</ul>
<h1>业务线列表(元组形式的)</h1>
<ul>
{% for row in v3 %}
<li>{{ row.0}}-{{ row.1}}-</li>
{% endfor %}
</ul>
</body>
</html>
host文件 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<table border="1">
<thead>
<tr>
<th>主机名</th>
<th>iP</th>
<th>端口</th>
<th>业务线名称</th>
</tr>
</thead>
<tbody>
{% for row in v1 %}
<tr hid="{{ row.nid }}" bid="{{ row.b_id }}"/>
<td>{{ row.hostname }}</td>
<td>{{ row.ip }}</td>
<td>{{ row.port }}</td>
<td>{{ row.b.caption }}</td>
{% endfor %}
</tbody>
</table> </body>
</html>
django环境准备学习笔记(三)的更多相关文章
- iView学习笔记(三):表格搜索,过滤及隐藏列操作
iView学习笔记(三):表格搜索,过滤及隐藏某列操作 1.后端准备工作 环境说明 python版本:3.6.6 Django版本:1.11.8 数据库:MariaDB 5.5.60 新建Django ...
- 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记
回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...
- kvm虚拟化学习笔记(三)之windows kvm虚拟机安装
KVM虚拟化学习笔记系列文章列表----------------------------------------kvm虚拟化学习笔记(一)之kvm虚拟化环境安装http://koumm.blog.51 ...
- 物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus
物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus 物联网 (IoT) 不只是新技术,还是与旧技术的集成,其关键在于通信.可用的通信方法各不相同,但是,各种不同的协议在将海量“事物”连接 ...
- SHELL学习笔记三
SHELL学习笔记一 SHELL学习笔记二 SHELL学习笔记三 for 命令 读取列表中的复杂值 从变量读取列表 从命令读取值 更改字段分隔符 用通配符读取目录 which 使用多个测试命令 unt ...
- ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心
作者:Grey 原文地址:ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 很多程序往 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
随机推荐
- 【NOIP2016提高A组8.12】礼物
题目 夏川的生日就要到了.作为夏川形式上的男朋友,季堂打算给夏川买一些生日礼物. 商店里一共有种礼物.夏川每得到一种礼物,就会获得相应喜悦值Wi(每种礼物的喜悦值不能重复获得). 每次,店员会按照一定 ...
- 同样是1ms子帧,为什么5G的时延比LTE小得多
转载:http://www.txrjy.com/forum.php?mod=viewthread&tid=1045092 个子帧中一定包含14个OFDM符号.当子载波间隔是15KHz时,1个5 ...
- JDK,JRE与JVM浅析
JAVA的两个特性: 1, 开源-指的是源代码免费 2,跨平台(可移植性好) 跨平台:是指跨操作系统 JVM(java virtual machine,java虚拟机) JVM就像是两国谈判时的使者充 ...
- springboot-mybatis-demo遇到的坑
目录 前言 问题&解决 1.初始化Maven工程过慢 2.Spring Boot 集成druid时时区问题和连接超时问题 3.完整工程下载 前言 环境: java version " ...
- CF643E Bear and Destroying Subtrees
题解 我们可以先写出\(dp\)式来. 设\(dp[u][i]\)表示以\(u\)为根的子树深度不超过\(i-1\)的概率 \(dp[u][i]=\prod (dp[v][i-1]+1)*\frac{ ...
- 《SQL Server 2012 T-SQL基础》读书笔记 - 8.数据修改
Chapter 8 Data Modification SQL Server 2008开始,支持一个语句中插入多行: INSERT INTO dbo.Orders (orderid, orderdat ...
- 北风设计模式课程---开放封闭原则(Open Closed Principle)
北风设计模式课程---开放封闭原则(Open Closed Principle) 一.总结 一句话总结: 抽象是开放封闭原则的关键. 1."所有的成员变量都应该设置为私有(Private)& ...
- functional-page-navigator 组件
functional-page-navigator 组件:是一个非常强大的组件,用于跳转插件的功能页 functional-page-navigator组件的属性: version:类型 字符串 跳转 ...
- debugfs linux rm 删除 恢复 Attempt to read block from filesystem resulted in short read while opening filesystem
w 删除具有空字符的文件 反斜杠来转义下一个字符 rm -R Samples\ -\ Copy well@well:/home/etc/project/apilinux/MarketplaceWebS ...
- 二十九、pycharm中报错“too many blank lines (3) ”等类似错误
报错如下图: 解决方法一: 鼠标移至报错处,按住Alt+enter键,选择ignore errors like this 方法二:找到设置File - Settings…… - Editor - In ...