python/SQLAchemy

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

安装:

1
pip3 install SQLAlchemy

SQLAlchemy本身无法操作数据库,其必须以来pymsql等第三方插件,Dialect用于和数据API进行交流,根据配置文件的不同调用不同的数据库API,从而实现对数据库的操作,如:

1
2
3
4
5
6
7
8
9
10
11
12
13
MySQL-Python
    mysql+mysqldb://<user>:<password>@<host>[:<port>]/<dbname>
   
pymysql
    mysql+pymysql://<username>:<password>@<host>/<dbname>[?<options>]
   
MySQL-Connector
    mysql+mysqlconnector://<user>:<password>@<host>[:<port>]/<dbname>
   
cx_Oracle
    oracle+cx_oracle://user:pass@host:port/dbname[?key=value&key=value...]
   
更多详见:http://docs.sqlalchemy.org/en/latest/dialects/index.html

ORM功能使用:

使用 ORM/Schema Type/SQL Expression Language/Engine/ConnectionPooling/Dialect 所有组件对数据进行操作。根据类创建对象,对象转换成SQL,执行SQL。

创建表单:

 from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,Integer,String,ForeignKey,UniqueConstraint,Index
from sqlalchemy.orm import sessionmaker,relationship
from sqlalchemy import create_engine
Base=declarative_base() #定义一个类(类==表,对象==行)
class UserType(Base):
__tablename__='usertype' ##设置表名
id=Column(Integer,primary_key=True,autoincrement=True) ##设置表行
title=Column(String(32),nullable=True,index=True) ##设置表行 class Useru(Base):
__tablename__='useru'
id=Column(Integer,primary_key=True,autoincrement=True)
name=Column(String(32),nullable=True,index=True)
email=Column(String(16),unique=True)
user_type_id=Column(Integer,ForeignKey('usertype.id'))
user_type=relationship('UserType',backref='xxoo')
##设置关联语句 relationship找指定的表名(UserType)创建列名(xxoo)实现双向关联,而在自身的表中创建出一列。 engine=create_engine("mysql+pymysql://root:@127.0.0.1:3306/lian?charset=utf8",max_overflow=5)
##设置连接引擎 # 找到所有继承了Base得类,类-SQL语句在数据库创建表
Base.metadata.create_all(engine) # 找到所有继承了Base得类,类-SQL语句在数据库删除表
# Base.metadata.drop_all(engine)

数据行操作:

 # 操作数据行:
# # 去引擎中获取一个连接
Session=sessionmaker(bind=engine)
session=Session()
# session.commit()
# session.close() ########表增加#######
# obj=Useru(name='话梅',email='92242@qq.com',user_type_id=2) 要插入每行的内容
# session.add(obj) 通过对象.add(要插入的变量名)进行添加
# session.commit() 通过对象.commit()进行提交
#------单个增加------- #======多个增加=======
# obj=[
# Useru(name='alex1',email='12321@qq.com'),
# Useru(name='alex2',email='12322@qq.com'),
# Useru(name='alex3',email='12323@qq.com'),
# Useru(name='alex4',email='12324@qq.com'),
# Useru(name='alex5',email='12325@qq.com')
#
# ]
#
# session.add_all(obj)
# session.commit() ########查看#########
# user_list=session.query(Useru)
# for row in user_list:
# print(row.name,row.id,row.user_type_id) #要进行表的修改和删除首先要查看表的内容
########表修改########
# session.query(UserType).filter(UserType.id==1).update({'title':'黄金用户'})
# session.commit()
# session.query(UserType).filter(UserType.id==1).update({UserType.title:UserType.title+"x"},synchronize_session=False)
# session.commit()
# session.query(Useru).filter(Useru.id > 0).update({Useru.name: Useru.name + "x"},synchronize_session=False)
# session.query(Useru).filter(Useru.id>2).update({'num':Users.num+1},synchronize_session='evaluate')
# session.commit()
########表删除#######
# session.query(UserType).filter(UserType.id==1).delete()
# session.commit() # type_list=session.query(UserType)
# for row in type_list:
# print(row.id,row.title)
# for j in row.xxoo:
# print('-----',j.name)

其他操作:

 ##其他操作##
# 条件:
# ret=session.query(Useru).filter_by(name='alex').all() ##filter_by 可以接收**args类型
# ret=session.query(Useru).filter(Useru.id>1,Useru.name=='aelx').all()
# ret=session.query(Useru).filter(Useru.id.between(1,3),Useru.name=='alex').all()
# ret=session.query(Useru).filter(Useru.id.in_([1,3,5])).all() ##in_就是相当于in
# ret=session.query(Useru).filter(~Useru.id.in_([1,3,5])).all() ##~ 相当于非的意思
# ret=session.query(Useru).filter(Useru.id.in_(session.query(Useru.id).filter_by(name='alex'))).all() ##多层套嵌条件查询
# from sqlalchemy import and_,or_
# ret =session.query(Useru).filter(and_(Useru.id>3,Useru.name=='alex')).all() ##and_ 相当于and
# ret=session.query(Useru).filter(or_(Useru,id<2,Useru.name=='alex')).all() ##or_ 相当于or
# ret=session.query(Useru).filter(
# or_(Useru.id <2,and_(Useru.name=='alex',Useru.id >3),Useru.extra !='')
# )##or_括号里都是or的关系,但是在括号里有一个是and 的关系
#
# 通配符:
# ret=session.query(Useru).filter(Useru.name.like('e%')).all() #查找name以e开头的
# ret=session.query(Useru).filter(~Useru.name.like('e%')).all() #查找name不是以e开头的
#
# 限制:
# ret=session.query(Useru)[1:2] #通过切片的实现分页的功能 # 排序:
# ret=session.query(Useru).order_by(Useru.name.desc()).all() #以降序进行排序
# ret=session.query(Useru).order_by(Useru.name.desc(),Useru.id.asc()).all() #开始以降序进行排序,如果过有重复的就按照id以升序排序 # 分组:
from sqlalchemy.sql import func
# ret =session.query(Useru).group_by(Useru.name).all() #以名字进行分组
# ret=session.query(
# func.max(Useru.id),
# func.sum(Useru.id),
# func.min(Useru.id)
# ).group_by(Useru.name).all() #以名字进行分组,然后操作合并后的列 # ret = session.query(
# func.max(Useru.id),
# func.sum(Useru.id),
# func.min(Useru.id)).group_by(Useru.name).having(func.min(Useru.id) >2).all() #有having二次筛选的 #
# print(ret) # 连表:
# ret=session.query(Useru,UserType).filter(UserType.id==Useru.id).all() #进行连表操作
# ret =session.query(Useru).join(UserType).all() # 这样是inner join (不显示空)
# ret = session.query(Useru).join(UserType,isouter=True).all() #这样是left join (显示空) #组合:
# q1=session.query(Useru.name).filter(Useru.id >2)
# q2=session.query(UserType.id).filter(UserType.id<1)
# ret=q1.union(q2).all() #这是去重组合
#
# q1 = session.query(Useru.name).filter(Useru.id > 2)
# q2 = session.query(UserType.id).filter(UserType.id < 1)
# ret = q1.union_all(q2).all() #这是不去
#
#
# 子查询:
# q3=session.query(Useru.name).filter(Useru.id >2).subquery()
# restt=session.query(q3).all()
# print(restt)

创建一对多等:

 # 一对多
class Favor(Base):
__tablename__ = 'favor'
nid = Column(Integer, primary_key=True)
caption = Column(String(50), default='red', unique=True) class Person(Base):
__tablename__ = 'person'
nid = Column(Integer, primary_key=True)
name = Column(String(32), index=True, nullable=True)
favor_id = Column(Integer, ForeignKey("favor.nid")) # 多对多
class Group(Base):
__tablename__ = 'group'
id = Column(Integer, primary_key=True)
name = Column(String(64), unique=True, nullable=False)
port = Column(Integer, default=22) class Server(Base):
__tablename__ = 'server' id = Column(Integer, primary_key=True, autoincrement=True)
hostname = Column(String(64), unique=True, nullable=False) class ServerToGroup(Base):
__tablename__ = 'servertogroup'
nid = Column(Integer, primary_key=True, autoincrement=True)
server_id = Column(Integer, ForeignKey('server.id'))
group_id = Column(Integer, ForeignKey('group.id'))

简述ORM原理:

 class User:
def __init__(self):
self.id=id
self.name=name
self.email=email
def order_by():
pass ogj=User('1.1.1.1','alex','34434@qq.com')
--------------------------------
obj.__dict__={'id':'1.1.1.1','name':'alex','email':'34434@qq.com'}
--------------------------------------------------------------------------
ORM的作用就是把类和对象方式解析成SQL语句(不进行连接,连接借助第三方模块)
code first 通过手动写SQL语句-------->类
db first 通过手动写类--------------->SQL语句

python/SQLAchemy的更多相关文章

  1. python SQLAchemy常用语法

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

  2. python SQLAchemy多外键关联

    关联同一张表的两个字段 Customer表有2个字段都关联了Address表 创建表结构 orm_many_fk.py 只创建表结构 from sqlalchemy import Integer, F ...

  3. python SQLAchemy外键关联

    join 1.利用filter import sqlalchemy from sqlalchemy import create_engine from sqlalchemy.ext.declarati ...

  4. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  5. Python之路-python(mysql介绍和安装、pymysql、ORM sqlachemy)

    本节内容 1.数据库介绍 2.mysql管理 3.mysql数据类型 4.常用mysql命令 创建数据库 外键 增删改查表 5.事务 6.索引 7.python 操作mysql 8.ORM sqlac ...

  6. Python操作mysql之SQLAchemy(ORM框架)

    SQLAchemy SQLAchemy 解析: SQLAchemy是python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作, 简言之便是:将对象转换成SQ ...

  7. Python自动化运维之18、Python操作 MySQL、pymysql、SQLAchemy

    一.MySQL 1.概述 什么是数据库 ? 答:数据的仓库,和Excel表中的行和列是差不多的,只是有各种约束和不同数据类型的表格 什么是 MySQL.Oracle.SQLite.Access.MS ...

  8. Python操作SQLAchemy

    如果对代码不懂就看这个:http://www.cnblogs.com/jixuege-1/p/6272888.html 本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql O ...

  9. mysql数据库----python操作mysql ------pymysql和SQLAchemy

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy 一.pymysql pymsql是Python中操作MySQL的模块,其使用方法和MySQ ...

随机推荐

  1. C语言switch/case圈复杂度优化重构

    软件重构是改善代码可读性.可扩展性.可维护性等目的的常见技术手段.圈复杂度作为一项软件质量度量指标,能从一定程度上反映这些内部质量需求(当然并不是全部),所以圈复杂度往往被很多项目采用作为软件质量的度 ...

  2. MSF添加ms17-010的exp脚本及攻击复现

    原文地址:https://bbs.ichunqiu.com/thread-23115-1-1.html 本来今晚在准备复现最近的CVE-2017-11882,由于本人是小白一枚,不知道这么添加msf的 ...

  3. Linux基础命令详解

    1 遍历目录 cd:change dicrectory的缩写 .或者./代表当前目录,..或../代表上一级目录,cd -代表进入上一次的目录. 2 文件和目录列表 ls:list的缩写,会显示目录下 ...

  4. Django——ORM

    Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...

  5. oracle 常用select sql语句

    本人认为很实用的几条语句 1)select ... from ...into... 2)insert into ...select ... 3)select ...from ...left join ...

  6. SQLite学习手册(数据表和视图)

    如何列出SQLite数据库中的所有表 SQLite数据库中的信息存在于一个内置表sqlite_master中,在查询器中可以用 select * from sqlite_master 来查看,如果只要 ...

  7. 多线程使用Lock实现生产者实现者代码

    package cn.com.servyou.qysdsjx.thread; import java.util.ArrayList; import java.util.List; import jav ...

  8. node 基础精简

    Node 创建node应用 引入require模块   var http = require("http"); 创建服务器   http.createServer() 绑定端口: ...

  9. Aizu - 0531 Paint Color

    白书例题,直接用书上的暴力压缩坐标是可以的,但是看了别人的博客的写法,大概是理解了思想但是看不懂为什么那么压缩,先放这,等明白了补上 #define debug #include<stdio.h ...

  10. JavaEE GenericServlet 解析

    从 上一篇 文章中可以看到,直接实现 Servlet 接口需要实现其所有方法,而这通常不是好的做法.相反,一种相对较好的做法是给出一个实现类来默认实现其所有方法或者部分方法,并开放给子类.而子类再在此 ...