一、在django后台admin管理页面添加自己增加的表结构

  通过终端命令:python3 manage.py makemigrations, python3 manage.py migrate

  我们在Django自带的后台管理页面可以看到Django自动生成表结构,那么要是想成自己的表结构需要这么做:

  首先web应用的models.py文件里面配置自己的数据库表,例如下面要建一张UserInfo表,并且用UserInfoAdmin指定后台表详情 :

   

class UserInfo(models.Model):
username = models.CharField(max_length=50)
password = models.CharField(max_length=50)
email = models.CharField(max_length=50)
userType = models.ForeignKey(UserType)#在上面声明过,所有可以直接写不加引号 class Meta:
verbose_name = '用户info'
verbose_name_plural = verbose_name # def __unicode__(self):#python2中使用
def __str__(self): # 这个方法类比打印对象一样自定义打印,list_display = ('name', 'age')会覆盖此方法效果
return '[username: %s, password: %s, email: %s]'%(self.username, self.password, self.email) class UserInfoAdmin(admin.ModelAdmin):
list_display = ('username', 'password', 'email')
search_fields = ('username', 'email')
list_display_links = ('password',)# which cannot be used unless 'list_display_links' is set.
list_editable = ('username','email',)

  写完之后我们只需要在admin.py里面注册就好了

from django.contrib import admin

# Register your models here.
from app01 import models admin.site.register(models.UserInfo, models.UserInfoAdmin) # admin.site.register(models.UserGroup)
# admin.site.register(models.Asset)

二、models相关操作

  1,增

    obj = models.UserInfo(username = 'xixi', password = '123', email = '123@kd.ocm', userType = models.UserType.objects.get(id = 2))
obj.save() obj = models.UserInfo(username='xixi', password='123', email='123@kd.ocm', userType_id=2)#注意此处是一个下划线
obj.save() models.UserInfo.objects.create(username='gan', password='123', email='123@kd.ocm', userType_id=1)
# TypeError: 'userType_name' is an invalid keyword argument for this function info_dict = {'username':'wei', 'password':'123', 'email':'123@kd.ocm', 'userType_id':1}#注意此处是一个下划线
models.UserInfo.objects.create(**info_dict)

  2,删

    def delNewsByID(self, id):
models.News.objects.filter(nid=id).delete()
def delNewsByTitle(self, id):
models.News.objects.filter(title=id).delete()

  3,改

    def updateNewsByID(self, id, title, content):
models.News.objects.filter(nid= id).update(title = title, content = content)
# news = models.News.objects.get(nid=id)
# news.title = 'updatetitle'
# news.save()

  4,查

    ref = models.UserInfo.objects.all().values('username', 'email')
print(ref, '----', ref.query)
# < QuerySet[{'username': 'wang', 'email': '123@qw.com'}, {'username': 'xixi', 'email': '123@kd.ocm'}, {'username': 'xixi', 'email': '123@kd.ocm'},
# { 'username': 'gan', 'email': '123@kd.ocm'}] > ---- SELECT`app01_userinfo`.`username`, `app01_userinfo`. `email` FROM `app01_userinfo` # ref = models.UserInfo.objects.all().values('username', 'userType__id', 'userType__name', 'userType__userinfo__username')#注意此处是2个下划线
ref = models.UserInfo.objects.filter(userType__name='administrator').values('username', 'userType__id', 'userType__name')
print(ref, '----', ref.query)
# < QuerySet[{'username': 'wang', 'userType__id': 1, 'userType__name': 'administrator'}, {'username': 'xixi', 'userType__id': 2, 'userType__name': 'user'}, { 'username': 'xixi', 'userType__id': 2, 'userType__name': 'user'}, {'username': 'gan', 'userType__id': 1, 'userType__name': 'administrator'}, { 'username': 'wei', 'userType__id': 1, 'userType__name': 'administrator'},
# {'username': 'wei', 'userType__id': 1, 'userType__name': 'administrator'}] > ---- SELECT `app01_userinfo`. `username`, `app01_userinfo`.
# `userType_id`, `app01_usertype`. `name` FROM `app01_userinfo` INNER JOIN `app01_usertype` ON(`app01_userinfo`. `userType_id` = `app01_usertype`.`id`)
for item in ref:
print(item, '==', type(item))

Django—models相关操作的更多相关文章

  1. django models 数据库操作

    django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...

  2. Django cookie相关操作

    Django cookie 的相关操作还是比较简单的 首先是存储cookie #定义设置cookie(储存) def save_cookie(request): #定义回应 response = Ht ...

  3. django models数据库操作

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  4. Django学习笔记之Django ORM相关操作

    一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...

  5. Django Models相关

    Models的相关知识 1. AutoField:自增整数类型.根据 ID 自增长的 Int字段 2. IntegerField:整数类型 3. BigIntegerField:大整数类型.用于数值较 ...

  6. Django Models 查询操作

    1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...

  7. Django session相关操作

    Django session 是存储在数据库中的所以要先跟数据库建立连接 本连接有Django跟数据库建立连接的操作:https://www.cnblogs.com/Niuxingyu/p/10296 ...

  8. Django数据库相关操作

    首先,在settings.py中加入应用的名称,让数据库知道使用的是哪个应用,然后给那个应用创建表. 在settings.py中配置数据库相关参数,默认使用sqlite3不用配置 编辑models.p ...

  9. Django框架详细介绍---ORM相关操作

    Django ORM相关操作 官方文档: https://docs.djangoproject.com/en/2.0/ref/models/querysets/ 1.必须掌握的十三个方法 <1& ...

随机推荐

  1. Windows核心编程读书笔记1

    今天特别困啊,这是为什么?!!刚刚把第一章看了一下,困到不行,所以写blog清醒一下. 第一章标题是“错误处理”,看了之后吓了一跳,难道第一章就讲这么高大上的东西?!不是不是,我现在的理解是,这章主要 ...

  2. ubuntu下如何安装codeblocks集成开发环境

    codeblocks是一个十分优秀的C/C++开发IDE,虽然后起之秀codelite目前来看大有超越之势哦. 不过在ubuntu下安装codeblocks却比较麻烦,不像其他linux发行版,比如s ...

  3. 双系统或三系统:Grub Rescue修复方法

    我是在装三系统的时候(1.WIN 7 ,2.Ubuntu 12.04 ,3.CentOS 6.4 ),中间步骤出错,造成引导区覆盖,grub乱掉了. 症状: 开机显示:GRUB loading err ...

  4. 初步认识thymeleaf:简单表达式和标签(一)

    初步认识Thymeleaf:简单表达式和标签.(一)   本文只适用于不会Java对HTML语言有基础的程序员们,是浏览了各大博客后收集整理,重新编辑的一篇文章,希望能对大家有所帮助.最后本文如果有哪 ...

  5. 学习MQ(二)基本概念

    学习MQ(二)基本概念 这次简单罗列一下MQ的基本概念,还有我对它们的理解 1.queue manager 队列管理器,这是MQ系统中最上层的一个概念.每一个queue manager都有一个侦听器, ...

  6. 多重影分身——C#中多线程的使用三(调用方法和传参)

    对Thread: 1.使用ThreadStart static void Main(string[] args) { Thread th1=new Thread(new ThreadStart(Say ...

  7. SQL Server 远程更新目标表数据

    分享一个远程更新目标库数据的存储过程,适用于更新列名一致,主键为Int类型,可远程链接的数据库. ** 温馨提示:如需转载本文,请注明内容出处.** 本文连接:http://www.cnblogs.c ...

  8. Python--简单接口测试实例(一)

    适用人员:初学python的测试人员,若对抓包不太清楚的可先学习抓包的知识 接口测试流程:发送请求-->返回响应-->结果判定-->生成报告 案例:下面以[今目标]新建客户为例来进行 ...

  9. UML类图10分钟快速入门 - From 圣杰

    虚线箭头指向依赖: 实线箭头指向关联: 虚线三角指向接口: 实线三角指向父类: 空心菱形能分离而独立存在,是聚合: 实心菱形精密关联不可分,是组合: 原文作者:圣杰 原文地址:http://www.j ...

  10. 关于C#中程序功能实现,对代码选择的思考

    body { background-color: rgb(60,60,60) } 接触C#语言只有短短几天时间,想要写出什么高大上的深入性研究文章,估计也是满篇的猜想和一些没有逻辑的推断.截至目前而言 ...