要想在一个另外的py文件中操作django,可以使用如下的代码

import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE",'mysite.settings') #mysite用的是自己的project
import django
django.setup() from app01 import models #app01是项目名

基本操作

方法 解释
get() 获取指定条件的对象,在views.py里面有且只能有一个,否则报错
all() 获取所有对象
filter() 获取满足条件的所有对象 ---》对象列表
exclude() 获取所有不满足条件的对象,也就是get()的取反
values() 括号内有参数就是获取指定字段的结果,不写就是显示所有字段
values_list() 区别于values,是以元组的形式来表示
order_by() 以某个字段来排列,- 是以降序排列
reverse() 对排列好的结果取反
distinct() 去重

models.Book.objects.all().values("price").distinct()
count() 计算结果的数量
first() 取出满足条件的第一个结果
last() 取出满足条件的最后一个结果
exists() 判断结果是否存在
 delete()  删除记录

models.Book.objects.filter(price__lte=100).delete()
 update()  修改记录

models.Book.objects.filter(title__startswith="py").update(price=120)

下面是举例:

首先我们设置打印格式:

class User(models.Model):
id=models.AutoField(primary_key=True)
name=models.CharField(max_length=32,db_column='user',verbose_name='姓名')
age=models.IntegerField(verbose_name='年龄')
birth=models.DateTimeField(auto_now=True,null=True) def __str__(self):
return "<User:id-{} name-{}>".format(self.id,self.name) class Meta:
#数据库的表面修改,自定义
db_table="user" #admin中显示的表名称
verbose_name='个人信息' #在admin中Site administration显示
verbose_name_plural='所有用户信息'

下面是一些双下滑线的操作命令:

__gt=     大于某个数

__lt=     小于某个数

__lte=    小于等于某个数

__in=[]    在某些数字中

__range=[1,3]  在一和三之间

__contain=    包含

__icontain=    包含忽略大小写

__year=       某个时间字段中的年

__startwith  endswith  以什么开始,以什么结尾

举例

ret1=models.User.objects.filter(id__gt=1)
# <QuerySet [<User: <User:id-2 name-he>>, <User: <User:id-3 name-ren>>, <User: <User:id-4 name-wo>>]>
print(ret1) #查询在某个区间的结果,可以放入不在数据库里面的id
ret2=models.User.objects.filter(id__in=[1,2,4,100])
print(ret2) #查询在某个范围的结果
ret3=models.User.objects.filter(id__range=[1,3])
print(ret3) #包含
ret4=models.User.objects.filter(name__contains='e')
print(ret4) #忽略大小写,在sqlite数据库里面和contains是一样的,可以使用mysql验证
ret5=models.User.objects.filter(name__icontains='e')
print(ret5) #查询字段birth的时间中year是2018
ret6=models.User.objects.filter(birth__year='')
print(ret6)

django之 使用py文件操作django项目中的表的更多相关文章

  1. 背水一战 Windows 10 (91) - 文件系统: Application Data 中的文件操作, Application Data 中的“设置”操作, 通过 uri 引用 Application Data 中的媒体

    [源码下载] 背水一战 Windows 10 (91) - 文件系统: Application Data 中的文件操作, Application Data 中的“设置”操作, 通过 uri 引用 Ap ...

  2. 怎样将.h文件添加到项目中

    作为C++的初学者,在运行别人的程序时,第一个遇到的问题就是无法将程序中写到的.h文件包含到项目中来.下面来写一下处理方法.本文以easyx.h为例进行说明 首先右键你的工程 选择Properties ...

  3. django模型models.py文件内容理解

    首先,要理解这句话:模型是你的数据的唯一的.权威的信息源.它包含你所存储数据的必要字段和行为.通常,每个模型对应数据库中唯一的一张表 基础:每个模型都是django.db.models.Model的一 ...

  4. pycharm 当有多个.py文件在开发环境中时,如何操作可以保证运行当前面对自己的文件?

    Alt+shift+F10选择自己的py文件,执行就可以了.

  5. SpringBoot项目中,表单的验证操作

    在创建Springboot项目中,我们使用了表单验证操作,这一操作将极大地简化我们编程的开发 1.接收数据,以及验证 @PostMapping("/save") public Mo ...

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

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

  7. 无状态的web应用(单个py文件的Django占位图片服务器)

    本文为作者原创,转载请注明出处(http://www.cnblogs.com/mar-q/)by 负赑屃 阅读本文建议了解Django框架的基本工作流程,了解WSGI应用,如果对以上不是很清楚,建议结 ...

  8. django项目中form表单和ajax的文件上传功能。

    form表单文件上传 路由 # from表单上传 path('formupload/',apply.formupload,name='formupload/'), 方法 # form表单文件上传 de ...

  9. 08 Django REST Framework 解决前后端分离项目中的跨域问题

    01-安装模块 pip install django-cors-headers 02-添加到INSTALL_APPS中 INSTALLED_APPS = ( ... 'corsheaders', .. ...

随机推荐

  1. Linux安装64位Mysql5.7

    首先下载mysql 地址:https://dev.mysql.com/downloads/mysql/ 下载社区版mysql 下载完成后:ftp上传到服务器 /user/local/目录下,这个自己定 ...

  2. like contains

    like :   %/%  = *****/**** contains:     abc    = 字符串中含有  abc

  3. Building tools 为什么是主流?

    一.building tools 为什么主流? Gradle 是目前比较流行的构建工具之一,Android Studio 中集成的就是 Gradle,并针对 Android 应用开发了插件 Gradl ...

  4. mysql8.0.13 的docker镜像安装

    1.从docker中获取mysql8.0.13镜像 docker pull mysql:8.0.13通过 docker images 命令查看镜像是否获取到了 2.运行 mysql8.0.13 镜像 ...

  5. WCF分布式服务2-服务配置部署

    上图整理了服务配置过程中所用到的基本的元素,大致的步骤: 1. 主要是首先要在调用服务的程序集中添加服务的一个引用. 2.  然后添加一个service并指定服务的名称.终结点. 在添加一个servi ...

  6. 新建虚拟机并与XShell连接(配置网卡)

    新建虚拟机并与XShell连接 一.新建虚拟机 下一步 下一步 选择CentOS版本,我的CentOS镜像是6.5版本64位,所以我选择CentOS 6 64. 然后点击下一步 可以自行更改位置,然后 ...

  7. Java六大必须理解的问题

    Java六大必须理解的问题 对于这个系列里的问题,每个学Java的人都应该搞懂.当然,如果只是学Java玩玩就无所谓了.如果你认为自己已经超越初学者了,却不很懂这些问题,请将你自己重归初学者行列.内容 ...

  8. shell中括号的特殊用法 linux if多条件判断

    一.   bash [  ] 单双括号 基本要素: Ø  [ ] 两个符号左右都要有空格分隔 Ø  内部操作符与操作变量之间要有空格:如  [  “a”  =  “b”  ] Ø  字符串比较中,&g ...

  9. C++ 跨语言调用 Java

    C++ 跨语言调用 Java Java JDK 提供了 JNI 接口供 C/C++ 程序调用 Java 编译后的类与方法,主要依赖于头文件(jni.h) 和 动态库(jvm.so/jvm.dll),由 ...

  10. linux下GCC编译文件

    Linux终端使用技巧: Ctrl+Alt+T打开终端 Ctrl+c死循环退出程序 Shift+Ctrl+T:新建标签页 Shift+Ctrl+N:新建窗口 Shift+Ctrl+Q:关闭终端 终端中 ...