Django—models相关操作
一、在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相关操作的更多相关文章
- django models 数据库操作
django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...
- Django cookie相关操作
Django cookie 的相关操作还是比较简单的 首先是存储cookie #定义设置cookie(储存) def save_cookie(request): #定义回应 response = Ht ...
- django models数据库操作
一.数据库操作 1.创建model表 基本结构 1 2 3 4 5 6 from django.db import models class userinfo(models.M ...
- Django学习笔记之Django ORM相关操作
一般操作 详细请参考官方文档 必知必会13条 <> all(): 查询所有结果 <> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <> ...
- Django Models相关
Models的相关知识 1. AutoField:自增整数类型.根据 ID 自增长的 Int字段 2. IntegerField:整数类型 3. BigIntegerField:大整数类型.用于数值较 ...
- Django Models 查询操作
1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...
- Django session相关操作
Django session 是存储在数据库中的所以要先跟数据库建立连接 本连接有Django跟数据库建立连接的操作:https://www.cnblogs.com/Niuxingyu/p/10296 ...
- Django数据库相关操作
首先,在settings.py中加入应用的名称,让数据库知道使用的是哪个应用,然后给那个应用创建表. 在settings.py中配置数据库相关参数,默认使用sqlite3不用配置 编辑models.p ...
- Django框架详细介绍---ORM相关操作
Django ORM相关操作 官方文档: https://docs.djangoproject.com/en/2.0/ref/models/querysets/ 1.必须掌握的十三个方法 <1& ...
随机推荐
- Linux 系统应用编程——线程基础
传统多任务操作系统中一个可以独立调度的任务(或称之为顺序执行流)是一个进程.每个程序加载到内存后只可以唯一地对应创建一个顺序执行流,即传统意义的进程.每个进程的全部系统资源是私有的,如虚拟地址空间,文 ...
- LeetCode(56)-Add Binary
题目: Given two binary strings, return their sum (also a binary string). For example, a = "11&quo ...
- JSP 分页显示数据 (Oracle)
要实现分页,首先我们要做的就是如何来编写SQL语句,网上也有很多,大家可以搜一下.在这里,我们使用一种比较常用的方式来编写SQL语句.代码如下: ----分页显示 select * from (sel ...
- 到底创建了几个String对象?
到底创建了几个String对象? 标签: 堆栈使用 对象创建 分类: 开发技术 关键字: java 面试题 string 创建几个对象 作者:臧圩人(zangweiren) 网址:http://zan ...
- COSO企业风险管理框架2017版发布!看看有哪些变化?
近期,COSO发布了新版(2017版)的企业风险管理框架:<企业风险管理—与战略和业绩的整合>.相较于2004年发布的上一版框架<企业风险管理—整合框架>,新框架强调了制定战略 ...
- javaWeb安全漏洞修复总结
1 Web安全介绍1 2 SQL注入.盲注1 2.1 SQL注入.盲注概述 1 2.2 安全风险及原因 2 2.3 AppScan扫描建议 2 2.4 应用程序解决方案 4 3 会话标识未更新7 3. ...
- JDBC连接数据库时候出错
错误提示如下: Fri May 13 09:06:04 CST 2016 WARN: Establishing SSL connection without server's identity ver ...
- java-随机生成用户名(中文版及英文版)
开发中遇到用户名随机生成的问题,总结了两个(中文版和英文版),相关方法在此,方便直接调用. 如下: //自动生成名字(中文) public static String getRandomJianHan ...
- java数组遍历、java方法定义
1.遍历数组for与foreach String [] test = {"java","php","bootstrap","vu ...
- sql server 多行数据合并成一列
首先是源数据: ),cip.CheckIn_StartTime, )),cip.CheckIn_EndTime, )),cip.Rental_Price)) as content from Check ...