一、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. Cocos2d-x CCControlPotentiometer之圆形音量button及特效

    1. 圆形音量button 事实上作者的本意应该是叫做"电位计button".可是我觉得它和我们的圆形音量button非常像,所以就这么叫它吧~先看效果: 好了,不多解释,本篇到此 ...

  2. ROS 订阅图像节点

    博客 http://blog.csdn.net/github_30605157/article/details/50990493 参考ROS原网站 http://wiki.ros.org/image_ ...

  3. Python高级网络编程系列之第三篇

    在高级篇二中,我们讲解了5中常用的IO模型,理解这些常用的IO模型,对于编写服务器程序有很大的帮助,可以提高我们的并发速度!因为在网络中通信主要的部分就是IO操作.在这一篇当中我们会重点讲解在第二篇当 ...

  4. go标准库的学习-strings-字符串操作

    参考https://studygolang.com/pkgdoc 导入方式: import "strings" strings包实现了用于操作字符的简单函数. 常用的几个函数: f ...

  5. LVS + Keepalived 理论

    LVS 纯理论: VRRP协议与工作原理 在现实的网络环境中,主机之间的通信都是通过配置静态路由或者(默认网关)来完成的,而主机之间的路由器一旦发生故障通信就会失效,因此这种通信模式当中,路由器就成了 ...

  6. 【Codeforces 1137A】Skyscrapers

    Codeforces 1137 A 题意:给一个矩阵,问对于每一个格子\((x,y)\),把第\(x\)行和第\(y\)列的值取出,要求将它们每一个赋上一个正整数,要求同一行.列中大小关系依然相同,问 ...

  7. Linux上vim编辑器缩进的设置(方便如书写python代码)

    因为刚刚安装了Ubuntu虚拟机,知乎大神推荐用VIM编辑器,然后发现在Python缩进上不方便,查了点资料,整理出来,以便自己以后忘了还可以再看看. 第一步: 打开终端,在终端上输入 vim ~/. ...

  8. Unity 消息管理(观察煮模式)

    一.首先定义一份消息号(消息号用来标记发出的每一条消息,接收者通过注册要监听的消息号来监听相应的消息) public enum MSG_IDS { NONE = -, MSG_TEST01 = , M ...

  9. c#中的多线程异常 (转载)

    1.对于Thread操作的异常处理 public static void Main() { try { Thread th = new Thread(DoWork); th.Start(); } ca ...

  10. C#批量插入数据到Sqlserver中的四种方式 - 转

    先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的是GUID,表中没有创建任何索引.GUID必然是比自增长要快的,因为你生成一个GUID算法所花的时间肯定比你从数据表中重新查询上一条记 ...