sqlalchemy orm 操作 MySQL
一、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的更多相关文章
- golang利用beego框架orm操作mysql
GO引入orm框架操作mysql 在beego框架中引入orm操作mysql需要进行的步骤: 第一步:导入orm框架依赖,导入mysql数据库的驱动依赖 import ( "github.c ...
- Flask学习笔记:数据库ORM操作MySQL+pymysql/mysql-python+SQLAlchemy/Flask-SQLAlchemy
Python中使用sqlalchemy插件可以实现ORM(Object Relationship Mapping,模型关系映射)框架,而Flask中的flask-sqlalchemy其实就是在sqla ...
- .net core使用orm操作mysql数据库
Mysql数据库由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库.MySQL是一个多用户.多线程的关系型数据库管理系 ...
- ORM操作mysql
创建表和添加数据 import sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import ...
- beego orm操作mysql数据库
慢慢弄起来~~ 按官方操作文档试一下. 那个err重复和user编号问题,以后再弄.. package main import ( "fmt" "github.com/a ...
- PHP ORM操作MySQL数据库
ORM----Oriented Relationship Mapper,即用面向对象的方式来操作数据库.归根结底,还是对于SQL语句的封装. 首先,我们的数据库有如下一张表: 我们希望能够对这张表,利 ...
- 【Django】ORM操作MySQL数据库遇到的一些问题
关于查询操作: 1.exact和iexact exact相当于= iexact相当于like(但是这里的like和数据库的不一样,没有给后面条件加上%%所以这里like和=的作用相似) artic ...
- python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy
内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...
- 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库
MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...
随机推荐
- sql语句如何将多个空格字符替换成一个空格字符
很多时候,数据表中某个字段的值会带有一个或多个空格字符串的情况,面对多样化的需求,我们可能需要将这些空格字符串去除,当然,这很好说,我们可以直接用replace(' ','')将单个空格变成无就可以了 ...
- v-bind指令动态绑定class和内联样式style
动态绑定class—概述 数据绑定(v-bind指令)一个常见需求是操作元素的 class 列表.因为class是元素的一个属性,我们可以用 v-bind 处理它们 我们只需要计算出表达式最终的字符串 ...
- easyUI tab页的显示与隐藏
每天学习一点点 编程PDF电子书免费下载: http://www.shitanlife.com/code 隐藏:tab_option = $('#tabid').tabs('getTab'," ...
- xiaowuga poj3735—Training little cats(特殊操作转化为矩阵操作)
题意:有n只猫,对其进行k次操作,然后反复这样操作m次. 其中g 表示 i 猫加1, e表示 i 猫为0:s表示 i 与 j 猫互换. 解释一下样例: 3 1 6g 1g 2g 2s 1 2g 3e ...
- QT+VS2013 1配置和安装
相关参考:http://www.cnblogs.com/ranjiewen/p/5318768.html 1下载 VS2013 微软官网查找 https://www.visualstudio.com ...
- treap学习笔记
treap是个很神奇的数据结构. 给你一个问题,你可以解决它吗? 这个问题需要treap这个数据结构. 众所周知,二叉查找树的查找效率低的原因是不平衡,而我们又不希望用各种奇奇怪怪的旋转来使它平衡,那 ...
- C语言程序设计II—第九周教学
第九周教学总结(22/4-28/4) 教学内容 本周的教学内容为: 9.1 输出平均分最高的学生信息 知识点:结构的概念.结构的定义形式.结构的嵌套定义.结构变量和结构成员变量的引用.重难点:结构变量 ...
- 软概(lesson 1):Javaweb实现用户登录界面
一.问题描述 二.网站系统开发所需要的技术 网站界面开发:html 后台所需要的技术:java基本内容,数据库语句,连接数据库实现增删改查 本题所用技术:数据库链接以及增加功能,基本html语句 技术 ...
- tornado学习篇(第二部)
执行字符串表示的函数,并为该函数提供全局变量 本篇的内容从题目中就可以看出来,就是为之后剖析tornado模板做准备, #!usr/bin/env python #coding:utf-8 n ...
- 3.5《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)—第三章小结
本章使用的重要命令总结在Table 5中 命令 描述 示例 curl 与URL交互 $ curl -O example.com which 指出程序的在计算机的路径 $ echo bar >&g ...