刚学到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数据库操作的更多相关文章

  1. 从命令行运行django数据库操作

    从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...

  2. Django数据库操作(增删改查)

    Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...

  3. Django 数据库操作

    Django 数据库操作 Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个 ...

  4. django数据库操作和中间件

    数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...

  5. 11.Django数据库操作(查)

    django.db.models.query.QuerySet1.可迭代2.可切片 官方文档:https://docs.djangoproject.com/en/1.9/ref/models/quer ...

  6. django 数据库操作详解

    Django配置使用mysql数据库 修改 settings.py 中的 DATABASES  注意:django框架不会自动帮我们生成mysql数据库,所以我们需要自己去创建. DATABASES ...

  7. Python Django 数据库操作

    1. 建立app 在自己的工程项目目录下输入: python manage.py startapp myapp(你想建立的app名称) 建立一个叫myapp的app 这样,在你的工程项目目录下会出现一 ...

  8. Django 数据库操作进阶F和Q操作

    Model中的F F 的操作通常的应用场景在于:公司对于每个员工,都涨500的工资.这个时候F就可以作为查询条件 1 2 3 from django.db.models import F models ...

  9. Python菜鸟之路:Django 数据库操作进阶F和Q操作

    Model中的F F 的操作通常的应用场景在于:公司对于每个员工,都涨500的工资.这个时候F就可以作为查询条件 from django.db.models import F models.UserI ...

随机推荐

  1. [sql server发布订阅]after触发器执行失败造成复制不成功

    结论: (以插入而例) 发布端的数据插入成功 订阅段的数据不会插入 实验 创建一张新表 create table test_subscriber (id int, mark varchar(2),in ...

  2. 转 关于C#中派生类调用基类构造函数的理解

    关于C#中派生类调用基类构造函数的理解 .c#class       本文中的默认构造函数是指在没有编写构造函数的情况下系统默认的无参构造函数 1.  当基类中没有自己编写构造函数时,派生类默认的调用 ...

  3. [转载] 动态链接库dll的 静态加载 与 动态加载

    转载自:http://blog.csdn.net/youxin2012/article/details/11538491 dll 两种链接方式  : 动态链接和静态链接(链接亦称加载)   动态链接是 ...

  4. [翻译]Java垃圾收集精粹(Java Garbage Collection Distilled)

    source URL: http://www.infoq.com/articles/Java_Garbage_Collection_Distilled Name: Java Garbage Colle ...

  5. Post和get乱码

    post 在web.xml中添加 <filter> <filter-name>CharacterEncodingFilter</filter-name> <f ...

  6. Ubuntu 安装软件的命令

    Ubuntu 安装软件的命令 安装flashplayer sudo apt-get install flashplugin-installer 安装百度云客户端 软件在百度云盘里面 安装必要的开发环境 ...

  7. 一个方法中的ajax在success中renturn一个值,但是方法的返回值是undefind?

    https://segmentfault.com/q/1010000003762379 A页面 console.log(handleData("search_list", &quo ...

  8. leetcode 155. Min Stack --------- java

    Design a stack that supports push, pop, top, and retrieving the minimum element in constant time. pu ...

  9. 第3章 rpm命令管理

    3-1 RPM包命名规则 3-2 安装命令 3-3 升级与卸载 3-4 RPM包查询 3-5 RPM包校验

  10. spark新能优化之shuffle新能调优

    shuffle调优参数 new SparkConf().set("spark.shuffle.consolidateFiles", "true") spark. ...