一、ORM介绍

orm英文全称object relational mapping,是对象映射关系程序,简单来说类似python这种面向对象的程序来说一切皆对象,但是我们使用的数据库却都是关系型的,为了保证一致的使用习惯,通过orm将编程语言的对象模型和数据库的关系模型建立映射关系,这样我们在使用编程语言对数据库进行操作的时候可以直接使用编程语言的对象模型进行操作就可以了,而不用直接使用SQL语言。

orm的优点:

隐藏了数据访问细节,“封闭”的通用数据库交互,ORM的核心。使得我们与数据库交互变得简单易行,并且完全不用考虑的SQL语句。快速开发,由此而来。

ORM使我们构造固化数据结构变得简单易行。

缺点:

无可避免的,自动化意味着映射和关联管理,代价是牺牲性能(早期,这是所有不喜欢ORM人的共同点)。现在的各种ORM框架都在尝试使用各种方法来减轻这块(LazyLoad,Cache),效果还是很显著的。

安装:

pip install sqlalchemy #也可以去下轮子安装,最近pypi不太好上

pip install pymysql

二、使用

2.1 在数据库中,当我们要建一个表时:

create table tablename (
field_id integer not null auto_increment,
field2 char(32) not null,
field3 varchar(64),
primary key (field_id));

写了一个简单的SQL语句,但是还有插入数据啊、查询啊、连表查询啊、增删改查等等,既然学到了orm也知道写SQL语句有多痛苦了

那我们用sqlalchemy来写一个吧!

sqlalchemy连接数据库语句:Python下使用 mysql+pymysql

mysql+pymysql://<username>:<password>@<host>/<dbname>[?<options>]

from sqlchemy import create_engine
from sqlchemy.ext.declarative import declarative_base
from sqlchemy import Integer, String, Column, ForeignKey
from sqlchemy.orm import sessionmaker engine = create_engine("mysql+pymysql://user_name:password@localhost/data_base_name",
encoding='utf-8', echo= True) Base = declarative_base() class User(Base): #1以下就是创建一个userinfo表了
__tablename__ = 'userinfo'
uid = Column(Integer, primary_key= True)
name = Column(String(32))
password = Column(String(64))
create_time = Column(String(64)) def __repr__(self):
return "<uid: {0} name: {1}".format(self.uid, self.name) Base.metadata.create_all(engine) #2在引擎上创建表

2的语句,这样就把我们在orm中的表远程连接到数据库,创建到database中了。

另一种创建方式,看看就好。

from sqlalchemy import Table, MetaData, Column, Integer, String, ForeignKey
from sqlalchemy.orm import mapper metadata = MetaData() user = Table('user', metadata,
Column('id', Integer, primary_key=True),
Column('name', String(50)),
Column('fullname', String(50)),
Column('password', String(12))
) class User(object):
def __init__(self, name, fullname, password):
self.name = name
self.fullname = fullname
self.password = password mapper(User, user)

三、增删改查

3.1 增

在orm里面进行操作都需要一个类似cusor的游标,这样来创建:

from sqlalchemy.orm import sessionmaker 引入该模块

Session_class = sessionmaker(bind= engine) 绑定engine ,会返回给你一个session类。注意这是个类

session = Session_class() 这样都得到了游标了

创建一条数据:

import time
time_now = time.time() #拿到当前的时间戳
user_obj = User(name= 'lina', password= '123456789', create_time= str(time_now))
session.add(user_obj) #将user_obj对象添加到事务中

注意:sqlalchemy默认开启事务所以这样还没成功,接下来:

session.commit() 只需要commit一下就好了,session还有个session.rollback()回滚函数,当你操作失败就自动调用了

3.2 查

条件查询:

list_user_obj = session.query(User).filter_by(name= 'lina').all() 这样我们就查询到了,通过.all()方法会返回所有User表里面name= 'lina'的对象组成一个列表,用.first()就只返回一个对象了

还有一个filter方法,不太建议,用法为参数要变为session.query(User).filter(User.name = name)变成User中的name对象

一般filter用在:模糊查询(统计)、多条件查询:

session.query(User).filter(User.name.like('li%')).count() 模糊查询,并通过.count()统计 session.query(User).filter(User.uid>2).filter(User.uid<5).all()`

分组

from sqlalchemy import func

session.query(func.count(User.name),User.name).group_by(User.name).all()

相当于原生sql为

select count(user.name) AS count_1, user.name AS user_name

FROM user GROUP BY user.name

3.3 改

user_obj = session.query(User).filter_by(name="lina").first() #查询想要修改的数据

user_obj.name = "david" #通过查询到的对象来修改对象中的属性

session.commit() #将修改后的对象comiit就完成一次修改了

3.4 删

查询到要删除的条数据,或者多个对象,直接调用session.delete(obj)然后提交一下就好了

obj = session.query(User).filter(User.name.like('%na').all()

session.delete(obj)

session.commit()

sqlalchemy orm 操作 MySQL的更多相关文章

  1. golang利用beego框架orm操作mysql

    GO引入orm框架操作mysql 在beego框架中引入orm操作mysql需要进行的步骤: 第一步:导入orm框架依赖,导入mysql数据库的驱动依赖 import ( "github.c ...

  2. Flask学习笔记:数据库ORM操作MySQL+pymysql/mysql-python+SQLAlchemy/Flask-SQLAlchemy

    Python中使用sqlalchemy插件可以实现ORM(Object Relationship Mapping,模型关系映射)框架,而Flask中的flask-sqlalchemy其实就是在sqla ...

  3. .net core使用orm操作mysql数据库

    Mysql数据库由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库.MySQL是一个多用户.多线程的关系型数据库管理系 ...

  4. ORM操作mysql

    创建表和添加数据 import sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import ...

  5. beego orm操作mysql数据库

    慢慢弄起来~~ 按官方操作文档试一下. 那个err重复和user编号问题,以后再弄.. package main import ( "fmt" "github.com/a ...

  6. PHP ORM操作MySQL数据库

    ORM----Oriented Relationship Mapper,即用面向对象的方式来操作数据库.归根结底,还是对于SQL语句的封装. 首先,我们的数据库有如下一张表: 我们希望能够对这张表,利 ...

  7. 【Django】ORM操作MySQL数据库遇到的一些问题

    关于查询操作: 1.exact和iexact exact相当于=   iexact相当于like(但是这里的like和数据库的不一样,没有给后面条件加上%%所以这里like和=的作用相似) artic ...

  8. python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy

    内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...

  9. 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库

    MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...

随机推荐

  1. oracle 索引扫描类型的分类与构造

    1. INDEX RANGE SCAN--请记住这个INDEX RANGE SCAN扫描方式drop table t purge;create table t as select * from dba ...

  2. PAT A1028 List Sorting (25 分)——排序,字符串输出用printf

    Excel can sort records according to any column. Now you are supposed to imitate this function. Input ...

  3. 分布式计算(二)使用Sqoop实现MySQL与HDFS数据迁移

    近期接触了一个需求,业务背景是需要将关系型数据库的数据传输至HDFS进行计算,计算完成后再将计算结果传输回关系型数据库.听到这个背景,脑海中就蹦出了Sqoop迁移工具,可以非常完美的支持上述场景. 当 ...

  4. Omi框架学习之旅 - 通过omi-id来实现组件通讯 及原理说明

    这个demo是通过omi-id来获取子类的实例,然后更改data属性,之后updata一下就好了. 老规矩:先上demo代码, 然后提出问题, 之后解答问题, 最后源码说明. class Hello ...

  5. [01] 初识SpringBoot:Hello World

    引用百科的一句话来说,SpringBoot是一款全新框架,设计目的是为了简化新Spring应用的初始搭建以及开发过程. 怎么讲呢,首先要明确的就是SpringBoot不是替代Spring的一种解决方案 ...

  6. CF908D New Year and Arbitrary Arrangement 期望、DP

    题目传送门 题意:给出正整数$pa,pb,k$,最开始你有一个空串,每一次你有$\frac{pa}{pa + pb}$的概率向串最后放一个$a$,有$\frac{pb}{pa + pb}$的概率向串最 ...

  7. sqlserver 隔离级别 - 转

    SQL-92标准中定义了四个隔离级别,这四个隔离级别在以前版本的SQL Server中即受到支持: READ UNCOMMITTED READ UNCOMMITTED是限制性最弱的隔离级别,因为该级别 ...

  8. VM下设置CenOS为静态IP

    在本机利用VM启动了4台虚拟机来搭建zookeeper集群,但是每次电脑重启后,虚拟机的IP都会变化,现在想来固定每台虚拟机的IP. 1.Step1:查看网关和子网掩码 记住选用NAT模式,点击NAT ...

  9. EF 利用PagedList进行分页并结合查询 方法2

    微软提供了PagedList分页,相信大家在网上也能搜索一大堆关于pagedList用法的博客,论坛.但是,在使用的过程中一不小心,就会掉入pagedList某种常规用法的陷阱. 我所说的某种常规用法 ...

  10. 面试3——java集合类总结(Map)

    1.概述: Java 中的map集合使用键值对(key-value)来保持数据,其中值(value)可以重复,键(key)必须唯一,但最多只能有一个key为空,它的主要实现类有HashMap.Hash ...