笔记-ORM-sqlalchemy

1.      ORM

1.1.    ORM框架简介

对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法,关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。因此,对象-关系映射(ORM)系统一般以中间件的形式存在,主要实现程序对象到关系数据库数据的映射。

1.2.    总结

简单来说,因为数据库和开发软件之间的低关联性,开发人员无法直接了解到类对象与DB中表结构及数据的关联性,在修改数据库表结构时需要分别操作数据库并同时修改各处代码,对项目而言是非常麻烦的。

将定义数据库表结构,操纵数据等功能能抽象化,独立出来,配合一定语法,就是ORM了。

对不同的数据库,语言之间的ORM库是不通用的,每一个组合都需要构建新的接口。

2.      SQLALchemy

2.1.    简介

The Python SQL Toolkit and Object Relational Mapper

2.2.    实验环境配置

mysql数据库安装配置

库安装

pip install sqlalchemy

3.      代码

# sqlalchemy使用测试
# sqlalchemy
from sqlalchemy import Column,String,create_engine,INTEGER,Text
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base

# 创建连接
# 格式mysql+pymysql://username:password@ip:db port/db
engine = create_engine('mysql+pymysql://dev_python:123456@localhost:3306/db_python', max_overflow=5)

# 测试连接是否可用
# execute是执行sql 语句
result = engine.execute('select * from t2')
#print(result.fetchall())

# 声明会话对象
session_class = sessionmaker(bind=engine)
session = session_class()

# 使用ORM方式创建表格
# 当然也可能通过执行SQL语句的方式创建表

# 声明一个基类
# 使用Declarative方法定义的映射类依据一个基类,
# 这个基类是维系类和数据表关系的目录-Declarative base class
# 在一个普通的模块入口中,应用通常只需要有一个base的实例。
# 通过declarative_base()功能创建一个基类:
base = declarative_base()

# 声明表类
class User(base):
    __tablename__ = 'user_1'

id = Column(String(20), primary_key=True)
    name = Column(String(40))
    password = Column(String(30))
    context = Column(String(100))
    col_test = Column(INTEGER)

def __repr__(self):
        return '%s(%r)' % (self.__class__.__name__, self.name)

# 创建表
# 注意:如果表已存在,并不会改动旧表
# 需要了解一下是否有只创建指定表的方法,好像没有。。。。
# print(dir(base.metadata))
# base.metadata.drop_all(engine)
#base.metadata.create_all(engine)
# 删除表
# base.metadata.drop_all(engine)

# 实例化一条记录
new_user = User(id='6', name='ed', password='edspassword', context='reflow
paint'
)
new_user1 = User(id='7', name='ed', password='edspassword', context='reflow
paint'
)

# 新增数据到类中并提交到数据库
#session.add(new_user)
#session.add(new_user1)
session.commit()
# session.rollback()

# 表关系
# 上面是最简单的表,没有外键
from sqlalchemy import ForeignKey

# 一对多
class User_2(base):
    __tablename__ = 'user_2'

id = Column(INTEGER,
primary_key=True)
    name = Column(String(64), nullable=False, index=True)
    password = Column(String(64), nullable=False)
    email = Column(String(64))
    #articles =
relationship('Article')

def __repr__(self):
        return '%s(%r)' % (self.__class__.__name__, self.name)

class Article(base):
    __tablename__ = 'articles'

id = Column(INTEGER,
primary_key=True)
    title = Column(String(255), nullable=False, index=True)
    content = Column(Text)
    user_id = Column(INTEGER, ForeignKey('user_2.id'))
    #author =
relationship('User')

def __repr__(self):
        return '%s(%r)' % (self.__class__.__name__, self.title)

# 多对多

class User_3(base):
    __tablename__ = 'user_3'

id = Column(INTEGER,
primary_key=True, autoincrement=True)
    name = Column(String(64))
    group = Column(INTEGER, ForeignKey('group.id'))
    department = Column(INTEGER,
ForeignKey('department.id'))
    password = Column(String(64))

class Group(base):
    __tablename__ = 'group'

id = Column(INTEGER,
primary_key=True)
    name = Column(String(64), unique=True, nullable=True)

class Department(base):
    __tablename__ = 'department'

id = Column(INTEGER,
primary_key=True, autoincrement=True)
    hostname = Column(String(64), unique=True, nullable=True)
    port = Column(INTEGER, default=22)

#base.metadata.drop_all(engine)
base.metadata.create_all(engine)

result = session.execute('show tables')
#print(result.fetchall())

# 基本的表创建完成了,下面是数据操作

# create
'''
new_obj = User(id='wefsfwe', name='sfd')
session.add(new_obj)
session.add_all([User(id='wef', name='wef')
               
,User(id='wgeer',name='ergrth')])
session.commit()
'''

result = session.query(User).all()
# print(result)

# read
result = session.query(User).all() # 返回User对象列表
result = session.query(User.id, User.name).all() # 返回tuple列表
result = session.query(User).filter_by(name='wef').all() # 返回User对象列表
result = session.query(User).filter_by(name='wef').first()
#同上
print(result)

for _ in session.query(User).order_by(User.id):
    #print(_.id, _.name)
   
pass
result = session.query(User).filter_by(id=r'6').first()
#print(result)

# update
session.query(User).filter(User.id == 'wef').update({'name':'32345'})
result = session.query(User.id, User.name).all() # 返回tuple列表
#print(result)
# 注意,无论是否提交,查询结果都已改变,但不提交数据库中的数据不会变
session.commit()

# delete

session.query(User).filter(User.id == 'wef').delete()
result = session.query(User.id, User.name).all() # 返回tuple列表
print(result)
# 同样,注意提交
session.commit()
result = session.query(User.id, User.name).all() # 返回tuple列表
print(result)

# 其它
# 条件查询
"""
#
 条件
ret = session.query(Users).filter_by(name='alex').all()
ret = session.query(Users).filter(Users.id > 1, Users.name == 'eric').all()
ret = session.query(Users).filter(Users.id.between(1, 3), Users.name ==
'eric').all()
ret = session.query(Users).filter(Users.id.in_([1,3,4])).all()
ret = session.query(Users).filter(~Users.id.in_([1,3,4])).all()
ret =
session.query(Users).filter(Users.id.in_(session.query(Users.id).filter_by(name='eric'))).all()
from sqlalchemy import and_, or_
ret = session.query(Users).filter(and_(Users.id > 3, Users.name ==
'eric')).all()
ret = session.query(Users).filter(or_(Users.id < 2, Users.name ==
'eric')).all()
ret = session.query(Users).filter(
    or_(
        Users.id < 2,
        and_(Users.name == 'eric',
Users.id > 3),
        Users.extra != ""
    )).all()

# 通配符
ret = session.query(Users).filter(Users.name.like('e%')).all()
ret = session.query(Users).filter(~Users.name.like('e%')).all()

# 限制
ret = session.query(Users)[1:2]

# 排序
ret = session.query(Users).order_by(Users.name.desc()).all()
ret = session.query(Users).order_by(Users.name.desc(), Users.id.asc()).all()

# 分组
from sqlalchemy.sql import func

ret = session.query(Users).group_by(Users.extra).all()
ret = session.query(
    func.max(Users.id),
    func.sum(Users.id),
   
func.min(Users.id)).group_by(Users.name).all()

ret = session.query(
    func.max(Users.id),
    func.sum(Users.id),
   
func.min(Users.id)).group_by(Users.name).having(func.min(Users.id)
>2).all()

# 连表

ret = session.query(Users, Favor).filter(Users.id == Favor.nid).all()

ret = session.query(Person).join(Favor).all()

ret = session.query(Person).join(Favor, isouter=True).all()

# 组合
q1 = session.query(Users.name).filter(Users.id > 2)
q2 = session.query(Favor.caption).filter(Favor.nid < 2)
ret = q1.union(q2).all()

q1 = session.query(Users.name).filter(Users.id > 2)
q2 = session.query(Favor.caption).filter(Favor.nid < 2)
ret = q1.union_all(q2).all()
"""

笔记-ORM-sqlalchemy的更多相关文章

  1. 20.Python笔记之SqlAlchemy使用

    Date:2016-03-27 Title:20.Python笔记之SqlAlchemy使用 Tags:python Category:Python 作者:刘耀 博客:www.liuyao.me 一. ...

  2. python ORM - sqlalchemy 操作使用

    python操作数据库 使用 ORM - sqlalchemy,pymsql 安装: pip install pymsq pip install sqlalchemy 一. '''连接数据库'''   ...

  3. tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作

    tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作 一. ORM #在服务器后台,数据是要储存在数据库的,但是如果项目在开发和部署的时候,是使用的不同的数据库,该怎么办?是不 ...

  4. tornado 07 数据库—ORM—SQLAlchemy—查询

    tornado 07 数据库—ORM—SQLAlchemy—查询 引言 #上节课使用query从数据库查询到了结果,但是query返回的对象是直接可用的吗 #在query.py内输入一下内容 from ...

  5. 【tips】ORM - SQLAlchemy操作MySQL数据库

    优先(官方文档SQLAlchemy-version1.2): sqlalchemy | 作者:斯芬克斯 推荐一(长篇幅version1.2.0b3):python约会之ORM-sqlalchemy | ...

  6. python 学习笔记十一 SQLALchemy ORM(进阶篇)

    SqlAlchemy ORM SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据A ...

  7. 冰冻三尺非一日之寒-mysql(orm/sqlalchemy)

    第十二章  mysql ORM介绍    2.sqlalchemy基本使用 ORM介绍: orm英文全称object relational mapping,就是对象映射关系程序,简单来说我们类似pyt ...

  8. Python开发【十二章】:ORM sqlalchemy

    一.对象映射关系(ORM) orm英文全称object relational mapping,就是对象映射关系程序,简单来说我们类似python这种面向对象的程序来说一切皆对象,但是我们使用的数据库却 ...

  9. mysql学习笔记(sqlalchemy安装及简单使用)

    博主最近在研究接口API自动化测试,之前设计的通过excel来实现自动化测试的框架实际使用中还是有很多局限性 这次博主的思路是: 1 搭建接口API管理平台 支持数据库方便维护 2 自动化测试平台可直 ...

  10. ORM SQLAlchemy - 对象关联

    >>> from sqlalchemy import Column, Integer, String >>> class User(Base): ... __tab ...

随机推荐

  1. CSS3伪类使用方法实例

    有时候在网页设计中会涉及到很多看上去很繁琐的设计图,这时候都会很让人头疼,那么这时候伪类就可以来帮助你解决问题了. 下面有一段实例大家可以参考一下: <!DOCTYPE html> < ...

  2. 浅谈position、table-cell、flex-box三种垂直(水平)居中技巧

    一.首先是喜闻乐见的position方法,经典且万能,用法如下: 父元素{ position:relative; } 子元素{ position:absolute; top:50%; left:50% ...

  3. SAP R/3 IDES 4.71 编译前后硬盘空间大小比较

    使用SGEN编译前 使用SGEN编译后

  4. 什么是TOPO学

    拓扑,一个跟门萨同样古怪的“科技Word”.其定义,对绝大多数读者而言,不一定需要理解,但无妨知道———拓扑学,数学的一门分科,研究几何图形在一对一的双方连续变换下不变的性质.不少门萨题,来自拓扑学, ...

  5. 【Node.js】一个愚蠢的Try Catch过错

    前段时间学习<深入浅出Nodejs>时,在第四章 - 异步编程中作者朴灵曾提到,异步编程的难点之一是异常处理,书中描述"尝试对异步方法进行try/catch操作只能捕获当次事件循 ...

  6. u-boot分析(六)----时钟初始化

    u-boot分析(六) 上篇博文我们按照210的启动流程,分析到了关闭看门狗,今天我们继续按照u-boot的启动流程进行分析,今天我们会主要分析时钟的初始化. 今天我们会用到的文档: 1.       ...

  7. 怎样解决putty终端乱码的方法

    原文地址:https://jingyan.baidu.com/article/3aed632e5f00ae701080913a.html?qq-pf-to=pcqq.c2c 终端输入:echo $LA ...

  8. MyEclipse导入JAVA工程显示红色叉叉的解决方法

    当我们有时候导入一个新的工程的时候可能会出现以下这种情况,基本上是因为jar包路径的问题. 解决方法如下: 1.右击工程,选择properties 2.选择 Java Build Path -> ...

  9. 修改FileZilla(FTP客户端)同时传输的文件数

    在菜单中点击“编辑”.“设置”,按照以下步骤操作:

  10. QR分解与最小二乘(转载自AndyJee)

    转载网址:http://www.cnblogs.com/AndyJee/p/3846455.html 主要内容: 1.QR分解定义 2.QR分解求法 3.QR分解与最小二乘 4.Matlab实现 一. ...