Django ORM基本配置

到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞:

  • 创建数据库,设计表结构和字段
  • 使用 MySQLdb 来连接数据库,并编写数据访问层代码
  • 业务逻辑层去调用数据访问层执行数据库操作

django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM),django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表

1、修改project数据库配置(程序主目录下的settings.py文件)

默认连接数据库为本地文件sqlite3:

  1. DATABASES = {
  2. 'default': {
  3. 'ENGINE': 'django.db.backends.sqlite3',
  4. 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  5. }
  6. } 

更换为指定的mysql数据库:

  1. DATABASES = {
  2. 'default': {
  3. 'ENGINE': 'django.db.backends.mysql',
  4. 'NAME':'zyweb', #数据库名
  5. 'USER': 'root', #账号
  6. 'PASSWORD': 'zyw@123', #密码
  7. 'HOST': '192.168.28.129', #mysql数据库IP
  8. 'PORT': '3306', #对端端口
  9. }
  10. }

2、创建定义数据库表结构文件(对应app目录下的models.py文件)

生成一个简单的数据库表:

  1. from django.db import models
  2.  
  3. # Create your models here.
  4.  
  5. class UserInfo(models.Model):
  6. # 创建的表名名称为cmdb_userinfo
  7. # 数据库默认创建id列 自增 主键
  8. # 用户名列 字符串类型 字符长度
  9. username = models.CharField(max_length=32) # max_length 字符长度
  10. passwd = models.CharField(max_length=64)

把对应的app名称加入到settings.py文件配置里:

  1. INSTALLED_APPS = [
  2. 'django.contrib.admin',
  3. 'django.contrib.auth',
  4. 'django.contrib.contenttypes',
  5. 'django.contrib.sessions',
  6. 'django.contrib.messages',
  7. 'django.contrib.staticfiles',
  8. 'cmdb', # 系统会加载cmdb下的model.py文件
  9. ]  

3、生成数据库表

执行下面命令:

  1. python manage.py makemigrations
  2. python manage.py migrate # 生成数据表

查看数据库表详情:

  1. mysql> desc cmdb_userinfo;
  2. +----------+-------------+------+-----+---------+----------------+
  3. | Field | Type | Null | Key | Default | Extra |
  4. +----------+-------------+------+-----+---------+----------------+
  5. | id | int(11) | NO | PRI | NULL | auto_increment |
  6. | username | varchar(32) | NO | | NULL | |
  7. | passwd | varchar(64) | NO | | NULL | |
  8. +----------+-------------+------+-----+---------+----------------+
  9. 3 rows in set (0.01 sec)

注意:Django默认用的MysqlDB模块连接数据库,但在python3.x里面还没有这个模块,所有需要把连接数据库的模块改成pymsyql,修改project目录下的init.py文件

  1. import pymysql
  2. pymysql.install_as_MySQLdb()

4、数据库字段和字段参数

  1. 1models.AutoField  自增列 = int(11)
  2.   如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True
  3. 2models.CharField  字符串字段
  4.   必须 max_length 参数
  5. 3models.BooleanField  布尔类型=tinyint(1)
  6.   不能为空,Blank=True
  7. 4models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
  8.   继承CharField,所以必须 max_lenght 参数
  9. 5models.DateField  日期类型 date
  10.   对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
  11. 6models.DateTimeField  日期类型 datetime
  12.   DateField的参数
  13. 7models.Decimal  十进制小数类型 = decimal
  14.   必须指定整数位max_digits和小数位decimal_places
  15. 8models.EmailField  字符串类型(正则表达式邮箱) =varchar
  16.   对字符串进行正则表达式
  17. 9models.FloatField  浮点类型 = double
  18. 10models.IntegerField  整形
  19. 11models.BigIntegerField  长整形
  20.   integer_field_ranges = {
  21.     'SmallIntegerField': (-32768, 32767),
  22.     'IntegerField': (-2147483648, 2147483647),
  23.     'BigIntegerField': (-9223372036854775808, 9223372036854775807),
  24.     'PositiveSmallIntegerField': (0, 32767),
  25.     'PositiveIntegerField': (0, 2147483647),
  26.   }
  27. 12、!models.IPAddressField  字符串类型(ip4正则表达式)不再使用
  28. 13models.GenericIPAddressField  字符串类型(ip4ip6是可选的)
  29.   参数protocol可以是:bothipv4ipv6
  30.   验证时,会根据设置报错
  31. 14models.NullBooleanField  允许为空的布尔类型
  32. 15models.PositiveIntegerFiel  正Integer
  33. 16models.PositiveSmallIntegerField  正smallInteger
  34. 17models.SlugField  减号、下划线、字母、数字
  35. 18models.SmallIntegerField  数字
  36.   数据库中的字段有:tinyintsmallintintbigint
  37. 19models.TextField  字符串=longtext
  38. 20models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
  39. 21models.URLField  字符串,地址正则表达式
  40. 22models.BinaryField  二进制
  41. 23models.ImageField 图片
  42. 24models.FilePathField 文件

所有字段...

  1. null -> db是否可以为空
  2. default -> 默认值
  3. primary_key -> 主键
  4. db_column -> 列名
  5. db_index -> 索引
  6. unique -> 唯一索引
  7. unique_for_date ->
  8. unique_for_month
  9. unique_for_year
  10. auto_now -> 更新时,自动更新为当前时间
  11. auto_now_add -> 创建时,自动生成时间
  12. choices -> django admin中显示下拉框,避免连表查询
  13. blank -> django admin是否可以为空
  14. verbose_name -> django admin显示字段中文
  15. editable -> django admin是否可以被编辑
  16. error_messages -> 错误信息欠
  17. help_text -> django admin提示
  18. validators -> django
  19. form, 自定义错误信息(欠)

所有字段参数...

5、DateTimeField 时区问题解决

在settings.py中设置:

  1. TIME_ZONE = 'Asia/Shanghai'
  2.  
  3. USE_TZ = False

Django 数据库基本操作

1、增加数据

① 第一种方式(最常用):

  1. from cmdb import models
  2. def ormadd(request):
  3. models.UserInfo.objects.create(username="James",passwd="8888")
  4.  
  5. return HttpResponse("ormadd")

② 第一种方式的另一种写法:

  1. from cmdb import models
  2. def ormadd(request):
  3. dicts = {'username':"James",'passwd':"8888"}
  4. models.UserInfo.objects.create(**dicts)
  5.  
  6. return HttpResponse("ormadd")

③ 第二种方式:  

  1. from cmdb import models
  2. def ormadd(request):
  3. obj = models.UserInfo(username='root',passwd='123')
  4. obj.save()
  5.  
  6. return HttpResponse("ormadd")

2、查询数据 

① 查询所有:

  1. from cmdb import models
  2. def ormselect(request):
  3. result = models.UserInfo.objects.all()
  4. print(result) # QuerySet类型 列表里每个元素都是一个obj对象
  5. # <QuerySet [<UserInfo: UserInfo object>, <UserInfo: UserInfo object>, <UserInfo: UserInfo object>]>
  6. for row in result:
  7. print(row.id,row.username,row.passwd)
  8. # 1 James 8888
  9. # 2 root 123
  10. # 3 James 8888
  11. return HttpResponse("ormselect")

② 查找指定字段:

  1. from cmdb import models
  2. def ormselect(request):
  3. result = models.UserInfo.objects.filter(username='root') # filter()里可以用,分开 表示and
  4. if result:
  5. for row in result:
  6. print(row.id,row.username,row.passwd)
  7. # 2 root 123
  8.  
  9. return HttpResponse("ormselect")

③ 获取查询第一条数据和统计匹配个数:

  1. from cmdb import models
  2. def ormselect(request):
  3. obj = models.UserInfo.objects.filter(username='root').filter() # 获取匹配的第一条字段
  4. c = models.UserInfo.objects.filter(username='root').count() # 获取匹配的字段个数
  5.  
  6. return HttpResponse("ormselect")

④ 比较值查询以及多条件查询:

  1. models.User.objects.filter(id=1,name='root') # id等于1或者name等于root
  2. models.User.objects.filter(id__gt=1,name='root') # id大于1
  3. models.User.objects.filter(id__lt=1) # id小于1
  4. models.User.objects.filter(id__gte=1) # id大等于
  5. models.User.objects.filter(id__lte=1) # id小等于

⑤ 指定查询数据库某个字段的所有数据

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <p>项目组(对象) v1</p>
  9. <ul>
  10. {% for row in v1 %}
  11. <li>{{ row.id }}-{{ row.caption }}-{{ row.code }}</li>
  12. {% endfor %}
  13. </ul>
  14. <p>项目组(字典) v2</p>
  15. <ul>
  16. {% for row in v2 %}
  17. <li>{{ row.id }}-{{ row.caption }}</li>
  18. {% endfor %}
  19. </ul>
  20. <p>项目组(元组) v3</p>
  21. <ul>
  22. {% for row in v3 %}
  23. <li>{{ row.0 }}-{{ row.1 }}</li>
  24. {% endfor %}
  25. </ul>
  26. </body>
  27. </html>

business.html

获取表单数据:

  1. def business(request):
  2. v1 = models.Business.objects.all()
  3. print("v1",v1)
  4. # v1 < QuerySet[ < Business: Business object >, < Business: Business object >,
  5. # < Business: Business object >, < Business: Business object >] >
  6.  
  7. v2 = models.Business.objects.all().values("id","caption")
  8. print("v2",v2)
  9. # v2 < QuerySet[{'caption': '运维', 'id': 1}, {'caption': '开发', 'id': 2}, {'caption': '销售', 'id': 3},
  10. # {'caption': '市场', 'id': 4}] >
  11.  
  12. v3 = models.Business.objects.all().values_list("id","caption")
  13. print("v3",v3)
  14. # v3 < QuerySet[(1, '运维'), (2, '开发'), (3, '销售'), (4, '市场')] >
  15.  
  16. return render(request,'business.html',{'v1':v1,'v2':v2,'v3':v3})

注:values和values_list后不指定字段的话,获取的是所有的字段数据

3、删除数据 

① 删除指定字段:

  1. from cmdb import models
  2. def ormdel(request):
  3. models.UserInfo.objects.filter(id=3).delete()
  4.  
  5. return HttpResponse("ormdel")

4、更新数据 

① 更新指定字段:

  1. from cmdb import models
  2. def ormupdate(request):
  3. models.UserInfo.objects.filter(id=2).update(passwd='99999')
  4.  
  5. return HttpResponse("ormupdate")

② 更新所有数据字段:

  1. from cmdb import models
  2. def ormupdate(request):
  3. models.UserInfo.objects.all().update(passwd='99999')
  4.  
  5. return HttpResponse("ormupdate")

  

Django 数据库一对多操作

1、 数据库表结构:

  1. from django.db import models
  2.  
  3. # Create your models here.
  4.  
  5. class UserInfo(models.Model):
  6. # 创建的表名名称为cmdb_userinfo
  7. username = models.CharField(max_length=32)
  8. passwd = models.CharField(max_length=64)
  9. # 关联外键 生成字段名为user_group_id
  10. user_group = models.ForeignKey("UserGroup",to_field='uid',default=1) #关联usergroup表的uid字段默认为1
  11.  
  12. class UserGroup(models.Model):
  13. # 创建的表名名称为cmdb_usergroup
  14. uid = models.AutoField(primary_key=True) #主键 自增
  15. caption = models.CharField(max_length=32,unique=True) #唯一索引
  16. ctime = models.DateField(auto_now_add=True,null=True) #创建时生成时间
  17. uptime = models.DateField(auto_now=True,null=True) #更新是自动更新时间

2、外键关联添加数据

  1. from cmdb import models
  2. def add(request):
  3. ug_obj = models.UserGroup.objects.create(caption='外键数据添加') #把外键obj直接当参数传入
  4. models.UserInfo.objects.create(username='James',passwd='123',user_group=ug_obj)
  5.  
  6. return HttpResponse('OK')

3、 外键关联表操作:

  1. from cmdb import models
  2. def ormadd(request):
  3. models.UserInfo.objects.create(username="James",passwd="8888")
  4. return HttpResponse("ormadd")
  5. def ormgroup(request):
  6. models.UserGroup.objects.create(caption="CEO")
  7. return HttpResponse("ormgroup")
  8.  
  9. def userinfo(request):
  10. obj = models.UserInfo.objects.all().first()
  11. # user_group_id 指定的是userinfo表里存的id号
  12. print(obj.id,obj.username,obj.user_group_id)
  13. # 1 James 1
  14.  
  15. # user_group 指定的是用户组obj对象
  16. print(obj.user_group.uid,obj.user_group.caption)
  17. # 1 CEO
  18. return HttpResponse("userinfo")

4、 跨表查询,神奇的双下划线__:

  1. class Business(models.Model):
  2. # id
  3. caption = models.CharField(max_length=32)
  4. code = models.CharField(max_length=32,null=True,default="SA")
  5.  
  6. class Host(models.Model):
  7. nid = models.AutoField(primary_key=True)
  8. hostname = models.CharField(max_length=32,db_index=True)
  9. ip = models.GenericIPAddressField(protocol="ipv4",db_index=True)
  10. port = models.IntegerField()
  11. b = models.ForeignKey(to="Business", to_field='id')

models.py

获取表单数据:

  1. def home(request):
  2. # b__capiton 通过双下划线直接跨表获取对应caption的数据
  3. v2 = models.Host.objects.filter(nid__gt=0).values('nid','hostname','b_id','b__caption')
  4. # < QuerySet[{'nid': 2, 'b__caption': '开发', 'hostname': '系统1', 'b_id': 2},
  5. # {'nid': 3, 'b__caption': '销售','hostname': '系统2', 'b_id': 3}>
  6.  
  7. return render(request, 'home.html')

5、**反向跨表查询

  1. from django.db import models
  2.  
  3. # Create your models here.
  4.  
  5. class UserType(models.Model):
  6. name = models.CharField(max_length=32)
  7.  
  8. class User(models.Model):
  9. name = models.CharField(max_length=32)
  10. pwd = models.CharField(max_length=32)
  11.  
  12. u_type = models.ForeignKey(to="UserType", to_field='id')

models.py

① 从对象中取值user_set

  1. from app01 import models
  2. def index(request):
  3. obj = models.UserType.objects.filter(id=1)
  4. for item in obj:
  5. print(item.id,item.name)
  6. print(item.user_set) # 指定关联表类名
  7. print(item.user_set.all())
  8. print(item.user_set.values('name','pwd'))
  9.  
  10. #1 技术部
  11. #app01.User.None
  12. #<QuerySet [<User: User object>, <User: User object>, <User: User object>]>
  13. #<QuerySet [{'name': 'lzl5', 'pwd': '123456'}, {'name': 'lzl1', 'pwd': '123456'}, {'name': 'lzl2', 'pwd': '123456'}]>
  14.  
  15. return HttpResponse('OK')

② 双下划线查询取值user__ 

  1. # 反向查询
  2. from app01 import models
  3. def index(request):
  4. obj = models.UserType.objects.all().values('name','user__name')
  5. print(obj)
  6. # < QuerySet[{'name': '技术部', 'user__name': 'lzl5'}, {'name': '技术部', 'user__name': 'lzl1'},
  7. # {'name': '技术部','user__name': 'lzl2'}]>
  8.  
  9. return HttpResponse('OK')
  1. related_name=None, # 反向操作时,使用的字段名,用于代替 【表名_set】 如: obj.表名_set.all()
  2. related_query_name=None, # 反向操作时,使用的连接前缀,用于替换【表名】 如: models.UserGroup.objects.filter(表名__字段名=1).values('表名__字段名')

涉及到的参数

Django 数据库多对多操作

1、自定义创建关系表

  1. class Host(models.Model):
  2. nid = models.AutoField(primary_key=True)
  3. hostname = models.CharField(max_length=32,db_index=True)
  4. ip = models.GenericIPAddressField(protocol="ipv4",db_index=True)
  5. port = models.IntegerField()
  6. b = models.ForeignKey(to="Business", to_field='id') # 这里先忽略
  7.  
  8. class Applications(models.Model):
  9. name = models.CharField(max_length=32)
  10.  
  11. class HostToAPP(models.Model):
  12. # 可以自定义多种字段
  13. hobj = models.ForeignKey(to='Host',to_field='nid')
  14. aobj = models.ForeignKey(to='Applications',to_field='id')

创建数据:

  1. HostToAPP.objects.create(hobj_id=1,aobj_id=2)

2、自动创建关系表

  1. class Host(models.Model):
  2. nid = models.AutoField(primary_key=True)
  3. hostname = models.CharField(max_length=32,db_index=True)
  4. ip = models.GenericIPAddressField(protocol="ipv4",db_index=True)
  5. port = models.IntegerField()
  6. b = models.ForeignKey(to="Business", to_field='id') # 这里先忽略
  7.  
  8. class Applications(models.Model):
  9. name = models.CharField(max_length=32)
  10.  
  11. r = models.ManyToManyField("Host")

自动生成第三张关联表cmdb_applications_r;下面我们就来看看针对这种情况下,如何对表进行操作

① 增加

  1. # 第三张表增加
  2. obj = models.Application.objects.get(id=1)
  3.  
  4. obj.r.add(1) # 创建id=1,nid=1
  5. obj.r.add(2) # 创建id=1,nid=2
  6. obj.r.add(2, 3, 4) # 创建id=1,nid=2、id=1,nid=3 、id=1,nid=4
  7. obj.r.add(*[1, 2, 3, 4]) # 同上

② 删除

  1. # 第三张表删除
  2. obj = models.Application.objects.get(id=1)
  3.  
  4. obj.r.remove(1) # 删除id=1,nid=1
  5. obj.r.remove(2,4) # 删除id=1,nid=2、id=1,nid=4
  6. obj.r.remove(*[1,2,3]) # 批量删
  7.  
  8. obj.r.clear() # 所有id=1的关系删除

③ 更新

  1. # 第三张表更新
  2. obj = models.Application.objects.get(id=1)
  3.  
  4. obj.r.set([3,5,7]) # 清空原来的id=1关系,创建id=1,nid=3;id=1,nid=5;id=3,nid=7
  5. # 等同于执行obj.r.clear()再执行obj.r.add(*[3,5,7])

④ 查询

  1. # 第三张表查询
  2. obj = models.Application.objects.get(id=1)
  3.  
  4. # 所有相关的主机对象“列表” QuerySet
  5. obj.r.all() # 所有对应的Host对象

  

Django 练习

1、增删改查管理后台

主project项目路由关系:

  1. from django.conf.urls import url,include
  2. from django.contrib import admin
  3.  
  4. urlpatterns = [
  5. url(r'^admin/', admin.site.urls),
  6. url(r'^cmdb/', include("app01.urls")),
  7. url(r'^monitor/', include("app02.urls")),
  8. ]

urls.py

程序逻辑处理目录app01下的文件

  1. from django.db import models
  2.  
  3. # Create your models here.
  4. # app01_userinfo
  5. # class Foo:
  6. # caption = models.CharField(max_length=32, unique=True)
  7.  
  8. class UserGroup(models.Model):
  9. uid = models.AutoField(primary_key=True)
  10. caption = models.CharField(max_length=32,unique=True)
  11. ctime = models.DateTimeField(auto_now_add=True, null=True)
  12. uptime = models.DateTimeField(auto_now=True, null=True)
  13. # f = models.ForeignKey('Foo')
  14. #
  15. # user_list = Userinfo.objects.all()
  16. # for row in user_list:
  17. # print(row.user_group_id)
  18. # print(row.user_group.uid)
  19. # print(row.user_group.caption)
  20. class UserInfo(models.Model):
  21. # id列,自增,主键
  22. # 用户名列,字符串类型,指定长度
  23. # 字符串、数字、时间、二进制
  24. username = models.CharField(max_length=32,blank=True,verbose_name='用户名')
  25. password = models.CharField(max_length=60, help_text='pwd')
  26. email = models.CharField(max_length=60)
  27. test = models.EmailField(max_length=19,null=True,error_messages={'invalid': '请输入密码'})
  28. # user_group_id 数字
  29. user_group = models.ForeignKey("UserGroup",to_field='uid') # (uid,catption,ctime,uptimew)
  30. user_type_choices = (
  31. (1, '超级用户'),
  32. (2, '普通用户'),
  33. (3, '普普通用户'),
  34. )
  35. user_type_id = models.IntegerField(choices=user_type_choices,default=1)
  36.  
  37. # test = models.URLField(max_length=19,null=True)
  38. # test = models.GenericIPAddressField()
  39. # gender = models.CharField(max_length=60, null=True)

models.py

  1. from django.conf.urls import url,include
  2. from django.contrib import admin
  3. from app01 import views
  4.  
  5. urlpatterns = [
  6. # url(r'^login/', views.login),
  7. # url(r'^index/', views.index),
  8. url(r'^user_info/', views.user_info),
  9. url(r'^userdetail-(?P<nid>\d+)/', views.user_detail),
  10. url(r'^userdel-(?P<nid>\d+)/', views.user_del),
  11. url(r'^useredit-(?P<nid>\d+)/', views.user_edit),
  12. # url(r'^orm/', views.orm),
  13. ]

urls.py

逻辑处理views.py文件:

  1. from app01 import models
  2. def user_info(request):
  3. if request.method == "GET":
  4. user_list = models.UserInfo.objects.all()
  5. group_list = models.UserGroup.objects.all()
  6. return render(request, 'user_info.html', {'user_list': user_list, "group_list": group_list})
  7. elif request.method == 'POST':
  8. u = request.POST.get('user')
  9. p = request.POST.get('pwd')
  10. models.UserInfo.objects.create(username=u,password=p)
  11. return redirect('/cmdb/user_info/')
  12.  
  13. def user_detail(request, nid):
  14. obj = models.UserInfo.objects.filter(id=nid).first()
  15. # 去单挑数据,如果不存在,直接报错
  16. # models.UserInfo.objects.get(id=nid)
  17. return render(request, 'user_detail.html', {'obj': obj})
  18.  
  19. def user_del(request, nid):
  20. models.UserInfo.objects.filter(id=nid).delete()
  21. return redirect('/cmdb/user_info/')
  22.  
  23. def user_edit(request, nid):
  24. if request.method == "GET":
  25. obj = models.UserInfo.objects.filter(id=nid).first()
  26. return render(request, 'user_edit.html',{'obj': obj})
  27. elif request.method == "POST":
  28. nid = request.POST.get('id')
  29. u = request.POST.get('username')
  30. p = request.POST.get('password')
  31. models.UserInfo.objects.filter(id=nid).update(username=u,password=p)
  32. return redirect('/cmdb/user_info/')

templates下的html模板:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. body{
  8. margin: 0;
  9. }
  10. .menu{
  11. display: block;
  12. padding: 5px;
  13.  
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <div style="height: 48px;background-color: black;color: white">
  19. 张扬凌晨三点玩愤怒的小鸟
  20. </div>
  21. <div>
  22. <div style="position: absolute;top:48px;bottom: 0;left: 0;width: 200px;background-color: brown;">
  23. <a class="menu" href="/cmdb/user_info/">用户管理</a>
  24. <a class="menu" href="/cmdb/user_group/">用户组管理</a>
  25. </div>
  26. <div style="position:absolute;top:48px;left: 210px;bottom: 0;right: 0;overflow: auto">
  27.  
  28. <h3>添加用户</h3>
  29. <form method="POST" action="/cmdb/user_info/">
  30. <input type="text" name="user" />
  31. <input type="text" name="pwd" />
  32.  
  33. <select name="group_id">
  34. {% for item in group_list %}
  35. <option value="{{ item.uid }}">{{ item.caption }}</option>
  36. {% endfor %}
  37. </select>
  38.  
  39. <input type="submit" value="添加"/>
  40. </form>
  41.  
  42. <h3>用户列表</h3>
  43. <ul>
  44. {% for row in user_list %}
  45. <li>
  46. <a href="/cmdb/userdetail-{{ row.id }}/">{{ row.username }}</a> |
  47. <span> {{ row.user_group.caption }} </span>
  48. <a href="/cmdb/userdel-{{ row.id }}/">删除</a> |
  49. <a href="/cmdb/useredit-{{ row.id }}/">编辑</a>
  50. </li>
  51. {% endfor %}
  52. </ul>
  53.  
  54. </div>
  55.  
  56. </div>
  57.  
  58. </body>
  59. </html>

user_info.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. body{
  8. margin: 0;
  9. }
  10. .menu{
  11. display: block;
  12. padding: 5px;
  13.  
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <div style="height: 48px;background-color: black;color: white">
  19. 张扬凌晨三点玩愤怒的小鸟
  20. </div>
  21. <div>
  22. <div style="position: absolute;top:48px;bottom: 0;left: 0;width: 200px;background-color: brown;">
  23. <a class="menu" href="/cmdb/user_info/">用户管理</a>
  24. <a class="menu" href="/cmdb/user_group/">用户组管理</a>
  25. </div>
  26. <div style="position:absolute;top:48px;left: 210px;bottom: 0;right: 0;overflow: auto">
  27.  
  28. <h1>用户详细信息</h1>
  29.  
  30. <h5>{{ obj.id }}</h5>
  31. <h5>{{ obj.name }}</h5>
  32. <h5>{{ obj.password }}</h5>
  33.  
  34. </div>
  35.  
  36. </div>
  37.  
  38. </body>
  39. </html>

user_detail.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. body{
  8. margin: 0;
  9. }
  10. .menu{
  11. display: block;
  12. padding: 5px;
  13.  
  14. }
  15. </style>
  16. </head>
  17. <body>
  18. <div style="height: 48px;background-color: black;color: white">
  19. 张扬凌晨三点玩愤怒的小鸟
  20. </div>
  21. <div>
  22. <div style="position: absolute;top:48px;bottom: 0;left: 0;width: 200px;background-color: brown;">
  23. <a class="menu" href="/cmdb/user_info/">用户管理</a>
  24. <a class="menu" href="/cmdb/user_group/">用户组管理</a>
  25. </div>
  26. <div style="position:absolute;top:48px;left: 210px;bottom: 0;right: 0;overflow: auto">
  27.  
  28. <h1>编辑用户</h1>
  29. <form method="post" action="/cmdb/useredit-{{ obj.id }}/">
  30. <input style="display: none" type="text" name="id" value="{{ obj.id }}" />
  31. <input type="text" name="username" value="{{ obj.username }}" />
  32. <input type="text" name="password" value="{{ obj.password }}"/>
  33. <input type="submit" value="提交" />
  34. </form>
  35.  
  36. </div>
  37.  
  38. </div>
  39.  
  40. </body>
  41. </html>

user_edit.html

《第二十四章》

Python之路【第十九章】:Django 数据库对象关系映射的更多相关文章

  1. 第十九章 Django的ORM映射机制

    第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...

  2. web前端基础知识-(八)Django进阶之数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  3. Django之数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  4. web框架-(四)Django进阶之数据库对象关系映射

    Django ORM基本配置 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去 ...

  5. Python学习(三十九)—— Django之Form组件

    一.构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=&qu ...

  6. Python之路(第二十九篇) 面向对象进阶:内置方法补充、异常处理

    一.__new__方法 __init__()是初始化方法,__new__()方法是构造方法,创建一个新的对象 实例化对象的时候,调用__init__()初始化之前,先调用了__new__()方法 __ ...

  7. Python之路(第十九篇)hashlib模块

    一.hashlib模块 HASH Hash,一般翻译做“散列”,也有直接音译为”哈希”的,就是把任意长度的输入(又叫做预映射,pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值 ...

  8. Python之路【第十九章】:Django进阶

    Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...

  9. python 教程 第十九章、 图形界面编程

    第十九章. 图形界面编程 import Tkinter top = Tkinter.Tk() hello = Tkinter.Label(top, text='Hello World!') hello ...

随机推荐

  1. MySql中的字符数据类型

    MySql中的varchar类型 1.varchar类型的变化 MySQL数据库的varchar类型在4.1以下的版本中的最大长度限制为255,其数据范围可以是0~255或1~255根据不同版本数据库 ...

  2. php多文件上传

    多文件上传<input type="file" name="file[]" multiple /> <?php function reArra ...

  3. 【MongoDB】6.关于MongoDB存储文件的 命令执行+代码执行

    参考:http://www.runoob.com/mongodb/mongodb-gridfs.html 1.命令执行 MongoDB GridFS GridFS 用于存储和恢复那些超过16M(BSO ...

  4. ftp下载在谷歌与火狐不同

    今天ftp点击下载按钮的时候火狐可以谷歌不行,上网查了一下网友提供两种方法确实可用记录如下 1.把"ftp"开头的网址修改为”http"开头的网址,即可顺利访问2.直接保 ...

  5. 浏览器-06 HTML和CSS解析2

    选择器 其实现由CSSSelector类来完成: CSSSelector的作用是储存从解析器生成的结果信息; 这里匹配指的是当需要为每个DOM中的节点计算样式时,WebKit需要根据当前的节点信息来从 ...

  6. Java基础知识梳理《一》

    一.Java数据类型(简单称之为“四类八种”) java 基本的数据类型长度都是固定的,好处是在实现跨平台时就统一了. 1.整型 byte short int long (分别是1,2,4,8个字节) ...

  7. 2016 Multi-University Training Contest 1 J.Subway

    Subway Time Limit: 7000/3500 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total Su ...

  8. CF #374 (Div. 2) D. 贪心,优先队列或set

    1.CF #374 (Div. 2)   D. Maxim and Array 2.总结:按绝对值最小贪心下去即可 3.题意:对n个数进行+x或-x的k次操作,要使操作之后的n个数乘积最小. (1)优 ...

  9. React独立组件间通信联动

    React是现在主流的高效的前端框架,其官方文档 http://reactjs.cn/react/docs/getting-started.html 在介绍组件间通信时只给出了父子组件间通信的方法,而 ...

  10. sweetalert api中文开发文档和手册

    官网和下载地址: http://t4t5.github.io/sweetalert/  2016年10月30日14:10:21 废话,目前php开发越来越API话,所以php方法很多都是json返回数 ...