使用Django框架中ORM系统实现对数据库数据增删改查

目录
  • 1.数据的增删改查----------增加数据
    • 在视图函数中导入User模型类,然后使用下面的方法添加数据:
  • 2.数据的增删改查----------查找数据
    • 这时在定义模型类时定义的__str__()方法的作用就表现了出来
    • User模型类导入
  • 3.数据的增删改查----------删除数据
  • 4.数据的增删改查----------修改数据

1.数据的增删改查----------增加数据

在视图函数中导入User模型类,然后使用下面的方法添加数据:

from django.http import HttpResponse
from .models import User
# Create your views here.
def add_user(request):
    #方法一
    taka = User(name='taka',age=18)
    taka.save()
    #方法二
    xiaopo = User()
    xiaopo.name = 'xiaopo'
    xiaopo.age = 18
    xiaopo.save()
    #方法三
    aa = User.objects.get_or_create(name='xiaohong',age=18)  #插入前会进行查找,如果没有相同的数据就会添加;如果有就不会。
    print(aa)       #会返回一个元组,第一个数据是添加成功的实例;第二个数据是True或False。(添加成功为True;反之为False)
    # 此处打印结果:   (<User: name:xiaohong, age:18>, True)

    # 插入前会进行查找,如果没有相同的数据就会添加;如果有就不会。   因为上面插入了相同数据,所以此处不会插入数据。
    User.objects.get_or_create(name='xiaohong',age=18)
    return HttpResponse("插入数据成功!")

实现效果:
(注意:分配一下路由,要访问到此视图才会执行!)

2.数据的增删改查----------查找数据

这时在定义模型类时定义的__str__()方法的作用就表现了出来

控制查询的数据显示的格式(即显示模型的简单表示)

from django.db import models
# Create your models here.
class User(models.Model):
    id = models.AutoField(primary_key=True)       #主键可以省略,Django默认会为我们加上一个名为id的主键,写的话就可以改主键的名字!
    name = models.CharField(max_length=50)        # CharField——字符串
    age = models.IntegerField()                   # IntegerField——整数
    def __str__(self):
        """
        返回模型的字符串表示
        我们告诉Django,默认应使用哪个属性来显示有关此模型的信息
        Django调用方法__str__()来显示模型的简单表示
        """
        return "name:%s, age:%s" %(self.name,self.age)

进行查询:

User模型类导入

from django.http import HttpResponse
from .models import User
def search_user(request):
    #查询所有记录对象
    rs1 = User.objects.all()
    print("这是所有记录对象:",rs1)			#通过观察,可以发现查询到的记录对象的输出方式就是模型中的__str__的格式.
    # 同时这个查询结果rs1是个queryset对象,是一个类似于列表的对象。具备列表里的一些常用方法,比如:切片[0:3],下标取值rs1[1]...但是下标取值的话不支持反向取值。
    #查询一个记录对象
    rs2 = User.objects.get(name="xiaopo")  # 此方法查询,如果不存在/存在多条都会报错!  所以一般通过id值。
    print("这是一个记录对象:",rs2)
    #查询满足条件的对象
    rs3 = User.objects.filter(name='xiaoming')  # 取不到则为空;多条的话都可以取到
    print("这是满足条件的对象:",rs3)
    return HttpResponse("查询数据成功!")

注意:
1.all()和filter()方法返回的是QuerySet对象,查询不到则为空(但咋样都不会报错,就很牛!)。
2.get()方式返回的单个对象,如果符合条件的对象有多个,则get报错!而且如果查询不到也会报错!

实现效果:

3.拓展——关于QuerySet简单整两句:

从数据库中查询出来的结果一般是一个集合,这个集合叫做 QuerySet(是一个类似于列表的对象,具备列表里的一些常用方法,比如:切片[0:3],下标取值rs1[1]…但是下标取值的话不支持反向取值).QuerySet是可迭代对象.QuerySet支持切片, 不支持负索引.可以用list强行将QuerySet变成列表.

3.数据的增删改查----------删除数据

from django.http import HttpResponse
from .models import User
def delete_user(request):
    #实例和QuerySet对象都具备删除方法!
    User.objects.get(id=1).delete()				#get方法得到的是单个对象(一个实例对象),所以是删除一条数据!
    User.objects.filter(age=18).delete()		#删除所有age属性值为18的数据!
    User.objects.all().delete()					#删除所有数据!
    s = User.objects.filter(age=18)
    s[1].delete()								#删除age值为18的数据中指定的一条
    return HttpResponse("删除数据成功!")

4.数据的增删改查----------修改数据

from django.http import HttpResponse
from .models import User
def update_user(request):
    #第一种方法:先查找到数据,然后再进行属性赋值修改(对于实例的修改)
    rs = User.objects.get(name="xiaoming")		#修改name属性值为xiaoming的name属性值为xiaowang(因为使用了get方法所以仅修改第一条!)
    rs.name='xiaowang'
    rs.save()
    #第二种方法:使用update方法直接修改(对于集合的修改,只能用于QuerySet对象)
    User.objects.filter(name='xiaowang').update(name='AAA')	#修改所有name属性值为xiaowang的name属性值为AAA!
    User.objects.all().update(age=22)			#修改所有数据的age属性值为22!
    return HttpResponse("修改数据成功!")

以上就是使用Django的ORM实现对数据库数据增删改查方法的详细内容,更多关于Django中实现ORM对数据库操作的资料请关注我们其它相关文章!

(0)

相关推荐

  • Django基于ORM操作数据库的方法详解

    本文实例讲述了Django基于ORM操作数据库的方法.分享给大家供大家参考,具体如下: 1.配置数据库 vim settings #HelloWorld/HelloWorld目录下 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', #mysql数据库中第一个库test 'NAME': 'test', 'USER': 'root', 'PASSWORD': '123456', 'HOST':'127.0.0.1', '

  • django的ORM操作 增加和查询

    ORM 对象关系映射 在数据库中,实现对数据的增删改查,使用的是SQ语句, 在django中,通过python代码,实现对数据库的增删改查,这就是ORM. 在python中,用类名 代表 django数据库的表名, 用对象 ,代表django数据库的一条记录, ORM 就是封装了SQ语句,给对象进行增删改查,实现对数据库的操作, 在settings 文件中,默认了splite的数据库,自己可以修改 DATABASES = { 'default': { 'ENGINE': 'django.db.b

  • Django中ORM表的创建和增删改查方法示例

    前言 Django作为重量级的Python web框架,在做项目时肯定少不了与数据库打交道,编程人员对数据库的语法简单的还行,但过多的数据库语句不是编程人员的重点对象.因此用ORM来操作数据库相当快捷.今天来介绍一下用ORM操作数据库. 一.创建Django项目 可以使用pycharme专业版直接快速创建.如果不是专业版也可以使用命令进行创建.下面列出命令行创建方式: django-admin startproject orm_test 这时会在当前目录创建文件夹名为orm_test,接下来进入

  • Django框架ORM数据库操作实例详解

    本文实例讲述了Django框架ORM数据库操作.分享给大家供大家参考,具体如下: 测试数据:BookInfo表 PeopleInfo表 一.增加 1.save: 对象 = 模型类( 字段名 = 值, 字段名 = 值, - ) 对象.save() 例: >>> book = BookInfo( ... name='python入门', ... pub_date='2010-1-1' ... ) >>> book.save() >>> book <B

  • 使用Django框架中ORM系统实现对数据库数据增删改查

    目录 1.数据的增删改查----------增加数据 在视图函数中导入User模型类,然后使用下面的方法添加数据: 2.数据的增删改查----------查找数据 这时在定义模型类时定义的__str__()方法的作用就表现了出来 User模型类导入 3.数据的增删改查----------删除数据 4.数据的增删改查----------修改数据 1.数据的增删改查----------增加数据 在视图函数中导入User模型类,然后使用下面的方法添加数据: from django.http impor

  • django框架使用views.py的函数对表进行增删改查内容操作详解【models.py中表的创建、views.py中函数的使用,基于对象的跨表查询】

    本文实例讲述了django框架使用views.py函数对表进行增删改查内容操作.分享给大家供大家参考,具体如下: models之对于表的创建有以下几种: 一对一:ForeignKey("Author",unique=True),  OneToOneField("Author") 一对多:ForeignKey(to="Publish",to_field="id",on_delete.CASCADE) 多对多:ManyToMany

  • 对Django的restful用法详解(自带的增删改查)

    什么是rest REST是所有Web应用都应该遵守的架构设计指导原则. Representational State Transfer,翻译是"表现层状态转化". 面向资源是REST最明显的特征,对于同一个资源的一组不同的操作.资源是服务器上一个可命名的抽象概念,资源是以名词为核心来组织的,首先关注的是名词. REST要求,必须通过统一的接口来对资源执行各种操作.对于每个资源只能执行一组有限的操作. GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT(PATCH)用

  • tp5(thinkPHP5)框架数据库Db增删改查常见操作总结

    本文实例讲述了tp5(thinkPHP5)框架数据库Db增删改查常见操作.分享给大家供大家参考,具体如下: 添加数据insert $data = [ 'name_cn' => '张三', 'name_en' => 'jack', ]; $res = Db::name('style')->insert($data); 添加数据. INSERT INTO `tf_style` (`name_cn` , `name_en`) VALUES ('张三' , 'jack') tp5还可以通过ins

  • JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能

    本文实例讲述了JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能.分享给大家供大家参考,具体如下: 单例模式 单例模式的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例 单例模式最初的定义出现于<设计模式>(艾迪生维斯理, 1994):"保证一个类仅有一个实例,并提供一个访问它的全局访问点." 单例模式定义:"一个类有且仅有一个实例,并且自行实例化向整个系统提供." var Singleton

  • python Django连接MySQL数据库做增删改查

    1.下载安装MySQLdb类库http://www.djangoproject.com/r/python-mysql/2.修改settings.py 配置数据属性 复制代码 代码如下: DATABASES = {    'default': {        'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.        'NAME': 'djang

  • iOS中FMDB数据库之增删改查使用实例

    FMDB是一个轻量级的数据库,用于将网络资源存储在本地.FMDB 将 SQLite API 进行了很友好的封装,使用上非常方便,对于那些使用纯 Sqlite API 来进行数据库操作的 app,可以考虑将其迁移到基于 FMDB 上,这对于以后数据库相关功能的开发维护,可以提高不少效率. 什么是FMDB FMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API FMDB的优点 使用起来更加面向对象,省去了很多麻烦.冗余的C语言代码 对比苹果自带的Core

  • C#在winform中实现数据增删改查等功能

    winform中利用ado.net实现对单表的增删改查的详细例子,具体如下: 1.前言: 运行环境:VS2013+SQL2008+Windows10 程序界面预览: 使用的主要控件:dataGridview和menuStrip等.  2.功能具体介绍: 1.首先,我们要先实现基本的数据操作,增删改查这几个操作. (1)先定义一个数据库操作的公共类: using System; using System.Collections.Generic; using System.Linq; using S

  • php中PDO方式实现数据库的增删改查

    需要开启php的pdo支持,php5.1以上版本支持 实现数据库连接单例化,有三要素 静态变量.静态实例化方法.私有构造函数 DPDO.php class DPDO{ private $DSN; private $DBUser; private $DBPwd; private $longLink; private $pdo; //私有构造函数 防止被直接实例化 private function __construct($dsn, $DBUser, $DBPwd, $longLink = fals

  • Spring框架+jdbcTemplate实现增删改查功能

    SpringMVC架构(Model(实体类),Service,Controller层) Controller(接收参数调用业务层)–>Service(调用持久层,处理业务逻辑)–>Dao(与数据库交互) 1. IOC(控制反转是一种设计思想而不是技术) DI(依赖注入):是IOC思想的一种技术实现 IOC容器是Spring提供的保存Bean对象的容器 Bean管理操作 1.Xml + 注解 2.javaConfig + 注解 通过xml配置Bean:TODO: 通过javaConfig 配置B

随机推荐