Django数据库操作
刚学到Django的数据库操作,把它记录下来,方便以后查看: 在Django中定义数据库表,并使用Django提供的方法来对数据库进行操作(增、删、改、查) 1、定义3个数据库表:
class Group(models.Model):
name = models.CharField(max_length=50,default=None) class User(models.Model):
name = models.CharField(max_length=50,default=None)
Email = models.CharField(max_length=50,default=None) group_relation = models.ManyToManyField('Group',default=None) #生成多对多表 class Asset(models.Model):
hostname = models.CharField(max_length=50,default=None)
create_date = models.DateTimeField(auto_now_add=True)
update_date = models.DateTimeField(auto_now=True)
2、向数据库中添加内容
Asset.objects.create(hostname=name) #多对多添加数据
u1 = User.objects.filter(id=1)
g1 = Group.objects.filter(id=1)
u1.group_relation.add(g1)
g1.user_set.add(u1)
3、从数据库中删除内容
Asset.objects.get(id=id).delete()
# 多对多删除数据
u1 = User.objects.filter(id=1)
g1 = Group.objects.filter(id=1)
u1.group_relation.delete(g1)
g1.user_set.delete(u1)
4、修改数据库中的内容
#根据id修改hostname
obj = Asset.objects.get(id=id)
obj.hostname=hostname
obj.save() #所有id大于传入参数的,就将hostname修改
Asset.objects.filter(id__gt=id).update(hostname=hostname)
5、查询数据库中的内容
# 多对多获取数据
u1 = User.objects.filter(id=1)
g1 = Group.objects.filter(id=1)
u1.group_relation.all()
u1.group_relation.all().filter(id=1)
g1.user_set.all()
g1.user_set.all().filter(email='') #查找所有id大于传入参数的数据
Asset.objects.filter(id__gt=id)
#查找所有hostname包含传入参数的数据
Asset.objects.filter(hostname__contains=hostname)
#查找类型id等于5的所有用户信息---type__id:type表示UserInfo表中的type字段(对应type表的外键),__id表示与userinfo表相关联的type表的id
UserIfo.objects.filter(type__id = 5)
#取出所有数据
Asset.objects.all()
#取出所有数据的前两条数据
Asset.objects.all()[0:2]
# 取出所有数据,并进行排序---id:按id正序排列,倒序就用'-id'
Asset.objects.all().order_by('id')
# 取出所有数据中的id和hostname列数据
Asset.objects.all().values('id','hostname')
Django数据库操作的更多相关文章
- 从命令行运行django数据库操作
从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...
- Django数据库操作(增删改查)
Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...
- Django 数据库操作
Django 数据库操作 Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个 ...
- django数据库操作和中间件
数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...
- 11.Django数据库操作(查)
django.db.models.query.QuerySet1.可迭代2.可切片 官方文档:https://docs.djangoproject.com/en/1.9/ref/models/quer ...
- django 数据库操作详解
Django配置使用mysql数据库 修改 settings.py 中的 DATABASES 注意:django框架不会自动帮我们生成mysql数据库,所以我们需要自己去创建. DATABASES ...
- Python Django 数据库操作
1. 建立app 在自己的工程项目目录下输入: python manage.py startapp myapp(你想建立的app名称) 建立一个叫myapp的app 这样,在你的工程项目目录下会出现一 ...
- Django 数据库操作进阶F和Q操作
Model中的F F 的操作通常的应用场景在于:公司对于每个员工,都涨500的工资.这个时候F就可以作为查询条件 1 2 3 from django.db.models import F models ...
- Python菜鸟之路:Django 数据库操作进阶F和Q操作
Model中的F F 的操作通常的应用场景在于:公司对于每个员工,都涨500的工资.这个时候F就可以作为查询条件 from django.db.models import F models.UserI ...
随机推荐
- 了解 C++ 默默编写并调用的函数
前言 对于一个类来说,最最基础的三类成员函数莫过于:构造函数,析构函数以及拷贝函数 (copy构造函数和=重载函数).即使你的类没有为这些函数做出定义,C++ 也会自动为你创建.本文将讲述的是 C++ ...
- archlinux下查看机器的ip地址
问题原因 默认archlinux没有安装ifconfig这个在其它发行版中常用的命令,刚开始不知道怎么查看机器的ip. 解决方案 使用archlinux中已经安装的ip命令.在后面跟上addr, ro ...
- Codeforces Round #368 (Div. 2)A B C 水 图 数学
A. Brain's Photos time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- Educational Codeforces Round 15 D 数学推公式
D. Road to Post Office time limit per test 1 second memory limit per test 256 megabytes input standa ...
- 用python做爬虫的例子
主要就是用了两个库,urllib和BeautifulSoup. 作用是从HTML中解析出解梦的查询词和具体的解释. # -*- coding: utf-8 -*- import urllib, url ...
- html---文本框样式;
一.一个单行文本框的例子 <form name="form1" action="mailto:3400982550@qq.com" method=&quo ...
- 3-5 RPM包校验
1.RPM包校验 <1>rpm -V 已安装的包名 <2>选项: -V 校验制定RPM包中的文件(verify) <3>说明: <1>若没有显示任何内容 ...
- PosPal银豹收银系统
http://pospal.cn/pc.html 注册公司的地址,便宜的快法务 http://www.kuaifawu.com/
- 论文笔记之:Semi-Supervised Learning with Generative Adversarial Networks
Semi-Supervised Learning with Generative Adversarial Networks 引言:本文将产生式对抗网络(GAN)拓展到半监督学习,通过强制判别器来输出类 ...
- 如果将彩色图像和灰度图像一起放进 CNN 中去,会是什么结果?
如果将彩色图像和灰度图像一起放进 CNN 中去,会是什么结果? 今天,坑爹的实验,我处理 SUN397 的时候,忘记去掉灰度图了,结果,利用微调后的 model 提取 feature,悲剧的发现,无论 ...