Django框架 ,Flask框架 ORM 以及pyrthon原生sql语句操作数据库

WHAT IS ORM?

ORM( Object Relational Mapping) 对象关系映射 , 即通过面向对象思维方式来实现对数据库的操作.

对模型类对象的操作转化为sql 语句

模块内实现数据库表和模型类的关系映射 : 开发人员只用对模型内的实例化对象进行相应操作,底层函数会自动转化为sql 语句来实现对数据库 的增改查删

优点 : 1操作简单更易理解代码编写简单, 2比起原生sql 语句可以节省代码量少可以节省大量开发时间, 符合目前开发的主流思想是用空间换取时间 缩短开发周期降低开发难度

缺点 : 建立了ORM映射 对模型类对象的操作 内层执行命令的依然是sql语句 这个反射的过程 存在不少的性能消耗问题,索性现在都有懒加载,缓存等机制 让ORM 性能消耗大大降低 , 相信未来会更低到可忽略

目前python主流 框架 Django,Flask 以及原生sql 语句 在实际编程的使用对比

原生sql

PyMySQL 模块

python3 连解数据库模块

实现流程

1 导入模块包
2 创建连接对象
3 获取游标对象
4 编写sql 语句
5 执行sql 语句
5.1 查询语句- 接受结果
   5.2 增删改语句 - 提交执行 或者回滚执行
6 关闭 游标对象
7 关闭连接对象
   

对数据库的CURD操作

Django

django.db 模块

Django框架自带数据库映射模块

实现流程

0 配置数据库
1 定义模型类
2 创建模型类的实例化对象
3 利用对象的方法实现对数据库的CURD

django.db 模块 定义模型类

导包 models

所有自定义模型类都继承 models.Model

案例:

class BookInfo(models.Model):
# django.db 会自动映射id 字段不用指定
# CharField 指定数据类型为字符串类型 参数是字段约束
name = models.CharField(default=0, verbose_name='书名') # 表库列名 映射属性名
# IntegerField 指定数据类型为整型 参数是字段约束
count = models.IntegerField(default=0, verbose_name='阅读量') # 表库列名 映射属性名 class Meta:
      db_table = 'tb_books' # 指明数据库表名 映射表
      verbose_name = '图书' # 在admin站点中显示的名称
      verbose_name_plural = verbose_name # 显示的复数名称
       
      def __str__(self):
      """定义每个数据对象的显示信息"""
      return self.btitle
   

对数据库的CURD操作

create:

案例

# 原生sql insert into tb_book values (0,"少年维特的烦恼", 1000)
方法一
book = BookInfo(name="少年维特的烦恼", count=1000)
book.save()
方法二 升级版
BookInfo.objects.create(
name="仲夏夜之梦",
count=1000
)

update:

案例

# 原生sql update tb_book set name = "围城" where id = 1;
方法一:
book = BookInfo.objects.get(id=1)
book.name = "围城"
book.save()
方法二 升级版:
# .objects.filter.update() 会修改所有过滤出的行 一般过滤条件用id
BookInfo.objects.filter(name="人间失格").update(name="西游记")

read:

案例

 # 获得所有数据行,相当于SQL中的SELECT * FROM
list_all = BookInfo.objects.all()
# filter相当于SQL中的WHERE,可设置条件过滤结果
list_filter = BookInfo.objects.filter(count=1000)
# 获取单个对象
response1 = BookInfo.objects.get(id=1)
 #数据排序
list_all = BookInfo.objects.all().order_by("count")
 # 限制返回的数据 相当于 SQL 中的 OFFSET 0 LIMIT 2;
 list_limit = Test.objects.all().order_by('count',desc)[0:2]

delete:

案例

原生sql delete from tb_book where id=1
test1 = BookInfo.objects.get(id=1)
test1.delete()

这样看ORM 与原生sql 相差不大

面向对象的优势在强大的继承封装能力

Django 框架加上 DRF 框架后 对数据库 的CURD 将直接被封装到底层,开发者只用指定路由,序列化器,模型类即可

完成CURD

Flask

SQLAlchemy模块

Flask 为轻量级的框架没有自带ORM包一般用SQLAlchemy模块

实现流程

0 配置数据库
1 定义模型类
2 创建模型类的实例化对象
3 利用对象的方法实现对数据库的CURD

SQLAlchemy模块定义模型类

db = SQLAlchemy(app) 所有模型类继承 db.Model

案例:

class BookInfo(db.Model):
# 映射数据库表
__tablename__ = 'user_basic'
# 映射列 参数(表类字段名, 数据类型, 其他约束..., admin站点中显示的名称)
id = db.Column('user_id', db.Integer, primary_key=True, doc='书籍id')

对数据库的CURD操作

SQLAlchemy 的操作指令更接近PyMySQL 模块

create:

案例

# 原生sql insert into tb_book values (0,"少年维特的烦恼", 1000)
方法一
book = BookInfo( name="少年维特的烦恼")
db.session.add(book)
db.session.add_all([user1, user2, user3]) # 批量增加
db.session.commit()

update

案例:

# 原生sql update tb_book set name = "围城" where id = 1;
方法一:
book = BookInfo.query.get(1)
book.name = "围城"
db.session.add(book)
db.session.commit()
方法二 升级版:
# django.db update 传入是 命名参数 SQLAlchemy update 传入是字典
BookInfo.query.filter_by(name="人间失格").update({(name:"西游记"}))
db.session.commit()

read

案例:

方法一:
# 获得所有数据行,相当于SQL中的SELECT * FROM
list_all = BookInfo.query.all()
# 查询第一个 有什么用?
book = book.query.first()
# 根据ID 查询,不存在主键返回 None [django.db 中可以根据更多字段查 get 不到会报错]
book = book.query.get(1)
方法二:
list_all = db.session.query(BookInfo).all()
book = db.session.query(BookInfo).first()
book = db.session.query(BookInfo).get(1)
# filter和filter_by相当于SQL中的WHERE,可设置条件过滤结果
list_filter = BookInfo.query.filter_by(count=1000) #filter_by
list_filter = BookInfo.query.filter(BookInfo.count==1000)
#filter是全局过滤要指定模型 条件要用python 比较符号
# 和fiest()同时使用过滤唯一数据 类似django.db get
# 偏移起始值得置位 offset
list_all = BookInfo.query.offset(2).all()
# 限制获取数据
list_all = BookInfo.query.limit(3).all()
#数据排序
list_all = BookInfo.query.order_by(BookInfo.id.all()
list_all = BookInfo.query.order_by(BookInfo.id.desc()).all()

Django&,Flask&pyrthon原生sql语句 基本操作的更多相关文章

  1. Django中执行原生SQL语句【新编辑】

    参考我的个人博客 这部分迁移到了个人博客中:Django中执行原生SQL语句 这里需要补充一下,还有一个extra方法: ret = models.Student.objects.all().extr ...

  2. Flask使用原生sql语句

    安装pip install flask-sqlalchemy 创建数据库对象 # 设置数据库连接地址app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://r ...

  3. 在django中使用原生sql语句

    raw # row方法:(掺杂着原生sql和orm来执行的操作) res = CookBook.objects.raw('select id as nid from epos_cookbook whe ...

  4. Django设置查看原生SQL语句

    LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBU ...

  5. 043:Django使用原生SQL语句操作数据库

    Django使用原生SQL语句操作数据库 Django配置连接数据库: 在操作数据库之前,首先先要连接数据库.这里我们以配置 MySQL 为例来讲解. Django 连接数据库,不需要单独的创建一个连 ...

  6. 05: MySQLdb 原生SQL语句操作数据库

    1.1 MySQLdb安装与简介 1.MySQLdb 模块的安装(python3中目前这个模块还不可用)参考博客 1. linux: yum install MySQL-python 2. windo ...

  7. Django中使用mysql数据库并使用原生sql语句操作

    Django自身默认使用sqlite3这个轻量级的数据库,但是当我们开发网站时,sqlite3就没有mysql好,sqlite3适合一些手机上开发使用的数据库. 准备的软件mysql数据库,版本5.7 ...

  8. django系列5.4--ORM中执行原生SQL语句, Python脚本中调用django环境

    ORM执行原生sql语句 在模型查询API不够用的情况下,我们还可以使用原始的SQL语句进行查询. Django 提供两种方法使用原始SQL进行查询:一种是使用raw()方法,进行原始SQL查询并返回 ...

  9. Django之ORM执行原生sql语句

    django中的ORM提供的操作功能有限,在模型提供的查询API不能满足实际工作需要时,可以在ORM中直接执行原生sql语句. Django 提供两种方法使用原生SQL进行查询:一种是使用raw()方 ...

随机推荐

  1. Java 从入门到进阶之路(三)

    之前的文章我们介绍了 Java 中的变量和基本数据类型,本章我们来看一下 Java 的运算符和表达式. 计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操 ...

  2. Servlet 获取 数组id进行批量删除

    把获取的复选框选中的 id(一般来说都是根据id 进行批量删除的) 从jsp页面 传值到Servlet中 jsp点击事件中: var array=[];  //先声明一个数组变量 var ids=$( ...

  3. Redis学习总结(五)--Redis集群创建

    在之前我们讲到了主从,但是对于大数据量的场景下我们就需要用到集群了,让我们来了解下集群吧. 为什么需要集群 单机内存太小 redis最高可以达到10万/s 请求,如果超过该频率呢? 数据分布方式 数据 ...

  4. GMTC 2019-前端夜话《聊聊前端工程师的成长和发展》会后简要总结

      今天晚上去参加了winter主持的前端夜话:聊聊前端工程师的成长和发展圆桌论坛分享会,真的是收益颇多,这次的这个嘉宾阵容也是很有诚意的,在现在前端领域都是有一定影响力的嘉宾,嘉宾阵容也列一下: 主 ...

  5. C函数指针状态机实现

    C函数指针状态机实现 有限状态机(finite state machine)简称FSM,表示有限个状态及在这些状态之间的转移和动作等行为的数学模型,在计算机领域有着广泛的应用.FSM是一种逻辑单元内部 ...

  6. Linux的权限属性信息1到10位分别什么意思

    要设置权限,就需要知道文件的一些基本属性和权限的分配规则. 在Linux中,ls命令常用来查看文件的属性,用于显示文件的文件名和相关属性. #ls -l 路径          [ls -l  等价于 ...

  7. codeforces 1041 E. Tree Reconstruction 和度数有关的构造树

    CF 1041E:http://codeforces.com/contest/1041/problem/E 题意: 告诉你一个树的节点个数,显然有n-1条边.已知去掉一条边后,两个集合中最大的节点值. ...

  8. Covered Points Count CF1000C 思维 前缀和 贪心

     Covered Points Count time limit per test 3 seconds memory limit per test 256 megabytes input standa ...

  9. hdu 4725 The Shortest Path in Nya Graph(建图+优先队列dijstra)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4725 题意:有n个点和n层,m条边,每一层的任意一个点都可以花费固定的值到下一层或者上一层的任意点 然 ...

  10. go Server示例

    示例1: package main import ( "fmt" "log" "net/http" "time" ) f ...