MySQL是几乎每一个项目都会使用的一个关系数据库,又因为它是开源免费的,所以很多企业都用它来作为自家后台的数据库。

BAT这类大公司除外,它们的业务数据是以亿级别来讨论的,而MySQL的单表6000万条数据运行在64位操作系统中已经很吃力

了,所以像BAT这类有钱,有需求的企业来说,用的数据库当然就是Oracle了。

抛开Oracle不说,MySQL的优越性还是挺突出的,有面对大数据量的分表操作和比较强大的多表关联查询,索引优化查询速度

等等。在中小型企业中还是很吃得开的。那么作为一个中小型的Django项目中,如何使用MySQL呢?本文的内容主要是介绍

Django项目中如何通过ORM关系映射来操作MySQL数据库,内容比较基础,提供给初学者作为借鉴使用。

关于什么是ORM关系映射,可以写一篇文章了,度娘上也有很多这类型的文章,我就不讨论了,这篇文章的主要内容还是关注

在基础操作上。

以下的案例一我自己曾经的一个项目,论坛网址为例来进行说明。

首先我为我的网站建立了一个Author表,一个Article表,一个News表(实际上不止这些表),这里就以这些

表为例进行说明。

Author表和Aticle表我做了一个多对多的关联,News表相对独立。

具体的表字段如下:

Author(缩减版,为了降低学习难度)
Id(用于索引) Name Phone Password Article表
tid Title Content Star(点赞数量) Comment News表
Nid Message

实际上以上这些表格的部分内容用非关系型数据库Mongodb来存更好,这里就不展开讨论了,以后有机会再谈谈

自己的一些学习心得。

一、数据库常用操作细节--增删查改

(1)插入数据

ORM有三种方法实现对数据库插入数据

1.Django中可以直接通过Views(视图)在DB(数据库)中创建记录

语法如下:
Entry.objects.create(属性1=值,属性2=值) 例如: Author.objects.create(id = 1, name=’Tom’, phone= '' , password = '')

概念理解:什么是Entry?

Entry的意思是实体,所有的数据库中的表都是通过实体来映射到程序中的。

2. 创建一个实体对象用于进行数据库的操作,当向数据库中增加数据时,可以通过save()方法完成增加数据

语法如下:
obj= Entry(属性1=值,属性2=值)
obj.save() 例如:
author = Author(id = 1, name=’Tom’, phone= '' , password = '')
author.save()

3. 通过字典创建实体对象,再调用save()

例如:
dic = {
id = 1,
name = ‘Tom’,
phone = ‘88888888888’,
password = ''
}
author = Author(**dic)
author.save()

(2)查询操作

敲黑板,查询操作是数据库操作的重点内容,Django支持不少的查询操作,但是复杂点的关联操作,ORM就无法实现了?那怎么办?没有办法了吗?

实现的方法是有的,用pymysql的原生语法去操作就可以了

好了,言归正传,开始讲ORM的查询操作~~

首先,要注意:所有的查询都要在Entry.objects的基础上完成

1. 基本查询操作

据说,Django已经查询语句的效率优化上已经达到最好,在ORM内部在B树的基础上做了一些修改。

1)语法:all()

用法:Entry.objects.all()     

相当于原生SQL的  select * from     

返回值:QuerySet(查询结果集),以字典的形式存储查询的结果,因此对结果取数据的时候可以使用python的字典方法

2)语法:Entry.objects.all().values()

查询所有记录的某一列的值

例如:Author.objects.all().values()  

相当于 select name from Author    

3)语法: Entry.objects.all().values_list(‘列1’ , ’列2’)

例如:Author.objects.all().values_list(‘name’,’age’ )

相当于 select name,age from Author

注意:一定是从查询结果集中进行筛选,即必须要有all()方法

1.1版本可以直接用values(‘name’,’age’)  取多个列值

4) 语法: Entry.objects.get()

这条查询语句只能查找一条记录,也只能返回一条记录。如果查询返回多条记录会报错,即传入的参数一定要使得查询的记录只有一条,一般可以用id值

如果不确定可以用try , except语句来捕捉错误

例如:Author.objects.get(id=4)

5) 语法: Entry.objects.exclude()

作用:对给定条件取反

  例如:房屋租赁系统,不想查哪个地区的房源
2 Entry.objects.exclude(id=3)
相当于 :select * from … where not id = 3;

5 又例如:筛选id不是3,同时年龄不是35的客户
Entry.objects.exclude(id=3,age=35)
相当于 :select * from … where not (id = 3 and age=35);

6) 语法: Entry.objects.order_by(‘列名1’ , ’ - 列名2’)

对所有查询数据进行排序,可以多级排序(只需要多写几个列名就行)

注意:默认是升序排序,需要降序的话,只需要在列名前加‘ - ’(减号)

7)语法:Entry.objects.filter()

根据自定义条件查询结果集。条件可以是一个,也可以是多个,多个的话,条件用’,’逗号隔开,其内部是使用AND来进行条件连接的。

1. 使用Entry的属性来作为filter()的条件

   例如:Author.objects.filter(id=1)  
相当于select * from author where id=1

2. 使用Field Lookups (查询谓词,主要结合filter或者get一起用)

(1) __exact 等值判断(用得比较少)

语法:Entry.objects.get(id__exact=num)

        例如:Author.objects.get(id__exact=11)

        相当于select * from author where id=11

(2)__contains 模糊查询

       例如:Entry.objects.get(headline__contains = ‘Lennon’)

       相当于 select … where headline like  %Lennon%;     

(3)__in 范围查询

        例如:Entry.objects.get(id__in =[1,3,5])

        相当于 select  …. where  id  in [1,3,5]

(4)__gt  __lt   大于,小于查询

         例如:Entry.objects.get(id__gt=3)

         相当于  select  … where  id>3

(5) __startwith  以…开始  (注意与__contains区分)

         Entry.objects.get(headline__startwith = ‘Lennon’)

         相当于select … where headline like  Lennon%;

3.子查询

例如:需求是获取比贾乃亮年龄要大的人

inner = Author.objects.filter(name__exat=’贾乃亮’).values(‘age’)  #获取贾乃亮的年龄
authors = Author.objects.filter(age__gt = inner)

实际上是嵌套查询

操作:

获取结果集的内容,因为结果集是许多条记录(集合)组成的一个列表,所以可以用下标来索引每一条记录,再通过索引来获得具体的字段

例如:name = authors[0][1]
第一天记录是贾乃亮相关的信息,信息下的第二个字段为姓名

二、 F()操作和Q()操作

1. F()操作

在执行中获取某列的值,再进行增删改查。

语法: F(‘列名’)

例如: SQL语句中 update  author set age=age+10

Django中写法:Author.object.all().update(age=F(‘age’)+10)

注意:在用F()函数前需要导包(下面的Q()函数也一样)

from  django.db.models  import F

应用:一般用在累加操作

2. Q()操作

Author.objects.filter(id=1,age=35)  这种情况是id=1 and age=35,无法写or逻辑运算符

可以使用以下的语法实现:

Author.objects.filter(  Q(id_exact=1)|Q(age=35),name=’王’   )   #也可以用,逗号表示and

and逻辑运算应用:登录系统的用户和密码验证

Django--数据库查询操作的更多相关文章

  1. Django 数据库查询

    #!/usr/bin/python #coding:utf-8 from django.shortcuts import render; from django.shortcuts import re ...

  2. django模型查询操作

    一旦创建好了数据模型,Django就会自动为我们提供一个数据库抽象API,允许创建.检索.更新和删除对象操作 下面的示例都是通过下面参考模型来对模型字段进行操作说明: from django.db i ...

  3. Django 数据库查询集合(多对多)

    Django 数据库查询集合(双下划线连表操作) 目录: 1.Django环境搭建 2.数据库建表 3.写入数据 4.查询语句 Django环境搭建 1.安装django pip install dj ...

  4. 数据库查询操作(fetchone,fetchall)

    数据库查询操作 Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据. fetchone(): 该方法获取下一个查询结果集.结果集是一个 ...

  5. Django 数据库查询集合(双下划线连表操作)

    Django是一款优秀的web框架,有着自己的ORM数据库模型.在项目中一直使用django数据库,写一篇文章专门记录一下数据库操作.略写django工程创建过程,详写查询过程.可以和sqlalche ...

  6. Django Models 查询操作

    1.准备数据表: from django.db import models class City(models.Model): name=models.CharField(max_length=32) ...

  7. Django 数据库常见操作

    首先要配置数据映射具体在这个连接里 https://www.cnblogs.com/Niuxingyu/p/10296143.html Django 建立数据库模型 #导包导入django数据库类 f ...

  8. 使用IDEA创建Spring boot项目,继承mybaits。并进行简单的数据库查询操作

    本文讲的是使用IEDA创建Spring boot项目,对于环境安装需要自行准备,如JDK1.8.Maven 3.3.IDEA编译器.Mysql5.7等需事前准备好. 1.创建Spring boot项目 ...

  9. Django视图之ORM数据库查询操作API

    查询表记录 查询相关API 操作:models.表名.objects.方法() all(): 查询所有结果 filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 get(**kwar ...

  10. django中orm多表查询,减少数据库查询操作

    .select_related()   的使用

随机推荐

  1. PCIE 2.0协议概念基本科普

    PCIE的概念:是电脑总线PCI的一种,它沿用现有的PCI编程概念及通信标准,但建基于更快的串行通信系统. 英特尔是该接口的主要支持者.PCIe仅应用于内部互连.由于PCIe是基于现有的PCI系统,只 ...

  2. 可变码率(英语:Variable bitrate,简称VBR)介绍

    可变码率(英语:Variable bitrate,简称VBR)这是一个用来形容通信服务质量(QoS for Quality of Service)的术语.和该词相对应的词是固定码率或固定比特率,英文c ...

  3. Spring Boot功能实战

    添加web功能启动器 添加了Spring Boot基础依赖后,如要使用web mvc功能,只需要添加如下启动器即可,Spring Boot会自动装配web功能. <dependencies> ...

  4. HoloLens开发手记 - 使用混合现实捕捉 Using mixed reality capture

    HoloLens给了用户混合真实世界和数字世界的体验.混合现实捕捉(MRC)使得你可以保存这种体验到图片或者视频.这使得你可以分享你的体验给其他人,这允许他们能看到和你所看到一样的全息图像.这些视频和 ...

  5. Go语言之Interface(一)

    Go语言之Interface(一) 什么是interface 在面向对象语言中接口是:接口定义了一个对象的行为,但在Go中接口就是方法签名的集合,当一个类型提供了这个接口中的所有的方法,就可以说这个类 ...

  6. web自动化测试---web页面元素的定位

    selenium提供了很多用于定位元素的方法,首先我们自己需要知道元素有哪些属性,这就需要用到安装测试环境中firebug来定位 打开firefox浏览器,按下F12键,我们就可以看到如下图所示的界面 ...

  7. 协程及Python中的协程

    1 协程 1.1协程的概念 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程.(其实并没有说明白~) 我觉得单说协程,比较抽象,如果对线程有一定了解 ...

  8. [深度学习]理解RNN, GRU, LSTM 网络

    Recurrent Neural Networks(RNN) 人类并不是每时每刻都从一片空白的大脑开始他们的思考.在你阅读这篇文章时候,你都是基于自己已经拥有的对先前所见词的理解来推断当前词的真实含义 ...

  9. #18 turtle模块

    前言 这一节继续记录模块,本节将记录Python中一个非常重要的画图模块——turtle,Here we go! 一.turtle模块 turtle(海龟)模块是Python中强大的内置画图模块,可以 ...

  10. webpack4打包报错:WARNING in configuration The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults fo

    运行命令webpack ./src/main.js ./dist/murenziwei.js后,目录上神马动静都没有,你以为在dist文件夹上会有murenziwei.js吗?毛都没有 警告和错误倒是 ...