F()可以将数据库里的数字类型的数据,转换为可以数字类型

首先要导入 from django.db.models import F

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 from django.db.models import F #导入F类 #逻辑处理模块
def special(request):
#获取yu_wen_lao_shi表里id等于1的那条数据,将shuzi字段的值自身加100
yu_wen_lao_shi.objects.filter(id=1).update(shuzi=F('shuzi') + 100) return render(request,'index.html',locals()) #打开页面

 Q()运算符:|或者、&并且

# Q
#
# 方式一:
# Q(nid__gt=10)
# Q(nid=8) | Q(nid__gt=10)
# Q(Q(nid=8) | Q(nid__gt=10)) & Q(caption='root')
# 方式二:
# con = Q()
# q1 = Q()
# q1.connector = 'OR'
# q1.children.append(('id', 1))
# q1.children.append(('id', 10))
# q1.children.append(('id', 9))
# q2 = Q()
# q2.connector = 'OR'
# q2.children.append(('c1', 1))
# q2.children.append(('c1', 10))
# q2.children.append(('c1', 9))
# con.add(q1, 'AND')
# con.add(q2, 'AND')
#
# models.Tb1.objects.filter(con)

实列:

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 from django.db.models import F,Q #导入F和Q from django.db.models import Count, Min, Max, Sum #逻辑处理模块
def special(request):
# Q(nid__gt=10)
a = yu_wen_lao_shi.objects.filter(Q(id__gt=3)).values() #获取id大于3的数据
print(a) #Q(nid=8) | Q(nid__gt=10)
b = yu_wen_lao_shi.objects.filter(Q(nl=20) | Q(nl=22)).values() #获取nl字段等于20,或者nl字段等于22的数据
print(b) c = yu_wen_lao_shi.objects.filter(Q(id__gt=2) & Q(nl=21)).values() #获取id大于2并且nl等于21的数据
print(c) return render(request,'index.html',locals()) #打开页面

执行原生SQL

  # from django.db import connection, connections
# cursor = connection.cursor() # cursor = connections['default'].cursor()
# cursor.execute("""SELECT * from auth_user where id = %s""", [1])
# row = cursor.fetchone()

queryset对象序列化

django的json类型模块serialize()

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 from django.db.models import F,Q #导入F和Q from django.core import serializers #django的将queryset对象转换成json类型模块
import json
#逻辑处理模块
def special(request):
# Q(nid__gt=10)
a = yu_wen_lao_shi.objects.filter(Q(id__gt=3)) #获取id大于3的数据
print(a) #得到queryset对象 b = serializers.serialize("json",a) #将queryset对象转换成json类型
print(b) #得到json类型 c = json.loads(b) #将json类型还原成Python数据类型
print(c)
return render(request,'index.html',locals()) #打开页面
# 返回:
# <QuerySet [<yu_wen_lao_shi: 张三4>, <yu_wen_lao_shi: 张三5>]>
# [{"model": "app1.yu_wen_lao_shi", "pk": 4, "fields": {"xm": "\u5f20\u4e094", "xb": "\u5973", "nl": "21", "shg": "174", "gz": "1500"}}, {"model": "app1.yu_wen_lao_shi", "pk": 5, "fields": {"xm": "\u5f20\u4e095", "xb": "\u5973", "nl": "23", "shg": "175", "gz": "1500"}}]
# [{'pk': 4, 'fields': {'xb': '女', 'shg': '174', 'gz': '1500', 'xm': '张三4', 'nl': '21'}, 'model': 'app1.yu_wen_lao_shi'}, {'pk': 5, 'fields': {'xb': '女', 'shg': '175', 'gz': '1500', 'xm': '张三5', 'nl': '23'}, 'model': 'app1.yu_wen_lao_shi'}]

list()将queryset对象转换成列表

from django.shortcuts import render
from app1.models import * #导入数据库操作模块 from django.db.models import F,Q #导入F和Q from django.core import serializers #django的将queryset对象转换成json类型模块
import json
#逻辑处理模块
def special(request):
# Q(nid__gt=10)
a = yu_wen_lao_shi.objects.filter(Q(id__gt=3)).values() #获取id大于3的数据
print(a) #得到queryset对象 b = list(a) #将queryset对象转换成列表
print(b) return render(request, 'index.html', locals()) # 打开页面 # 返回:
# <QuerySet [{'xb': '女', 'gz': '1500', 'id': 4, 'xm': '张三4', 'nl': '21', 'shg': '174'}, {'xb': '女', 'gz': '1500', 'id': 5, 'xm': '张三5', 'nl': '23', 'shg': '175'}]>
# [{'xb': '女', 'gz': '1500', 'id': 4, 'xm': '张三4', 'nl': '21', 'shg': '174'}, {'xb': '女', 'gz': '1500', 'id': 5, 'xm': '张三5', 'nl': '23', 'shg': '175'}]

由于json.dumps时无法处理datetime日期,所以可以通过自定义处理器来做扩展,如:

queryset对象

import json
from datetime import date
from datetime import datetime class JsonCustomEncoder(json.JSONEncoder): def default(self, field): if isinstance(field, datetime):
return o.strftime('%Y-%m-%d %H:%M:%S')
elif isinstance(field, date):
return o.strftime('%Y-%m-%d')
else:
return json.JSONEncoder.default(self, field) # ds = json.dumps(queryset对象, cls=JsonCustomEncoder)

补充: models 中实现一个字段的默认值为当前登录用户

class ding_dan_guan_liAdmin(object):
list_display = ['nnd', 'ke_hu_qing_kuang', 'luyinyuan_chengben', 'shou_kuan_qing_kuang',
'ding_dan_zhuang_tai', 'jiaoyi_qingkuang', 'wengao_fabu']
model_icon = 'fa fa-pencil-square-o'
readonly_fields = ['nnd', 'xiadan_ren']
style_fields = {'bei_zhu': 'ueditor', 'wen_gao': 'ueditor'} # 使用富文本框插件 def save_models(self):
obj = self.new_obj
request = self.request
# 获取添加到订单用户值
yhu = obj.xiadan_ren
if not yhu:
obj.xiadan_ren = request.user
obj.save() xadmin.site.register(ding_dan_guan_li, ding_dan_guan_liAdmin)

七 Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化的更多相关文章

  1. 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  2. 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化

    第三百零九节,Django框架,models.py模块,数据库操作——F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...

  3. 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

    第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...

  4. 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置

    Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...

  5. 五 Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  6. 四 Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置

    Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...

  7. 六 Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多

    链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.ForeignKey()外键字段一对多,值是要外键的表类 from __future__ import unico ...

  8. Django框架----models.py(数据库操作文件)

    利用一个中间模块 帮助我们连接数据库,写SQL语句,执行SQL语句,拿到结果 models.py 一.数据的对应关系 1. 类 ---> 表 2. 对象 ---> 数据行 3. 属性 -- ...

  9. Django框架06 /orm多表操作

    Django框架06 /orm多表操作 目录 Django框架06 /orm多表操作 1. admin相关操作 2. 创建模型 3. 增加 4. 删除 5. 修改 6. 基于对象的跨表查询 7. 基于 ...

随机推荐

  1. 最小生成树——Prim(普利姆)算法

    [0]README 0.1) 本文总结于 数据结构与算法分析, 源代码均为原创, 旨在 理解Prim算法的idea 并用 源代码加以实现: 0.2)最小生成树的基础知识,参见 http://blog. ...

  2. Oracle关于快速缓存区应用原理

    为什么oracle可以对于大量数据进行訪问时候能彰显出更加出色表现,就是通过所谓的快速缓存来实现数据的快速运算与操作.在之前的博文中我已经说过sql的运行原理,当我们訪问数据库的数据时候,首先不是从数 ...

  3. [c++]对象指针,引用的操作

    1.time类保存在"htime.h"中.要求: ⑴ 数据成员包括时(hour).分(minute).秒(second),为私有成员: ⑵ 能给数据成员提供值的成员函数(默认值为0 ...

  4. 【php】global的使用与php的全局变量

    php的全局变量和其余编程语言是不同的,在大多数的编程语言中,全局变量在其下的函数.类中自己主动生效.除非被局部变量覆盖,或者根本就不同意再声明同样名称与类型的局部变量.可是php中的全局变量不是默认 ...

  5. Nodejs通过thrift访问Java服务

    上一篇文章中实现了用Java作为thrift客户端和服务端.接下来我们用nodejs作为客户端访问一下.Nodejs的安装可以查看http://www.cnblogs.com/xucheng/p/39 ...

  6. yii2.0 中的队列

    a yii2 extension to make simple to use queue. yii2-queue让队列的使用在yii2中变得更轻松,她为各种队列组件的使用提供了一个标准的接口,您只需要 ...

  7. Obj-C数组以及字符串拼接与分割

    本文转载至 http://mobile.51cto.com/iphone-392148.htm Obj-C只是增加了一点“特殊语料”的C语言,所以可以用printf()代替NSLog().但我们建议使 ...

  8. 爬虫入门【1】urllib.request库用法简介

    urlopen方法 打开指定的URL urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None, capath=None, ca ...

  9. intellij idea pycharm phpstorm webstorm 这些编辑器像 sublime text 一样使用 ctrl d 来操作光标多选。

    在Windows 和 Linux 快捷键是 Alt+J,在 Mac OS X 系统下快捷键是 Ctrl+G . 参考 https://blog.jetbrains.com/phpstorm/2014/ ...

  10. WCF基础之数据协定

    数据协定最重要的当然就是DataContract和DataMember.这两个特性能应用到类.结构和枚举.这个两个特性跟服务契约的特点是一样的,只有被DataContract标记的类和类中被标记Dat ...