Python的SQLalchemy模块连接与操作MySQL的基础示例


Posted in Python onJuly 11, 2016

一、SQLalchemy简介
SQLAlchemy是一个开源的SQL工具包,基本Python编程语言的MIT许可证而发布的对象关系映射器。SQLAlchemy提供了“一个熟知的企业级全套持久性模式,使用ORM等独立SQLAlchemy的一个优势在于其允许开发人员首先考虑数据模型,并能决定稍后可视化数据的方式。
二、SQLAlchempy的安装
首先需安装mysql,这里就不再多说了.....
然后,下载SQLAlchemy(http://www.sqlalchemy.org/download.html),这里我们以Windows系统为例,然后打开cmd,在安装包文件目录下,运行

python setup.py install

,通过python下输入

import sqlalchemy

,执行未报错则表示安装成功
 
三、SQLAlchemy的使用实例

1、完成简单数据表信息查询

# 1. 导入模块
from sqlalchemy import *
from sqlclchemy.orm import *
# 2. 建立数据库引擎
mysql_engine = create_engine("$address", echo, module)
 #address 数据库://用户名:密码(没有密码则为空)@主机名:端口/数据库名
 #echo标识用于设置通过python标准日志模块完成的SQLAlchemy日志系统,当开启日志功能,我们将能看到所有的SQL生成代码
# 3. 建立连接
connection = mysql_engine.connect()
# 4. 查询表信息
result = connection.execute("select name from t_name)
for row in result:
 print "name: ", row['name']
# 5. 关闭连接
connection.close()

 
2、插入新的数据表

# 1. 导入模块
from sqlalchemy import *
from sqlclchemy.orm import *
# 2. 建立数据库引擎
mysql_engine = create_engine("$address", echo, module)
 #address 数据库://用户名:密码(没有密码则为空)@主机名:端口/数据库名
 #echo标识用于设置通过python标准日志模块完成的SQLAlchemy日志系统,当开启日志功能,我们将能看到所有的SQL生成代码
# 3. 设置metadata并将其绑定到数据库引擎
metadata = Metadata(mysql_engine)
# 4. 定义需新建的表
users = Table('users', metadata,Column('user_id', Integer, primary_key=True),
 Column('name', String(40)),
 Column('age', Integer),
 Column('password', String),)
 #Table实现方式与SQL语言中的CRETE TABLE类似
# 5. 在数据库中创建表
metadata.create_all(mysql_engine)
 #向数据库发出CREATE TABLE命令,由此数据库新建名为users的表
 #调用时会检查已经存在的表结构,因此可重复调用
# 6. 创建一个与数据库中的users表匹配的python类
class user():
 def __int__(self, name, fullname, password):
 self.name = name
 self.fullname = fullname
 self.passwd = passwd
 #python类的属性需与users表的列名一致
# 7. 设置映射
from sqlalchemy.orm import mapper
mapper(user, users)
 # mapper()创建一个新的Mapper对象,与定义的类相关联
#需要注意的是,通过mapper建立映射的数据表必须带有主键,如果没有主键就无法定位某个table的某行row, 
#如果无法定位某行row, 就无法做Object-relational mapping这样的映射
# 8. 创建session
Session = sessionmaker(bind=mysql_egnine)
session = Session()
 #由此我们只需对python的user类的操作,后台数据库的具体实现交由session完成
# 9. 执行
session.commit()
 #实现与数据库的交互
# 10. 查询
usr_info = session.query(user).filter_by(age=12).first()
 #返回数据库中年纪12岁的第一条数据

上面结合SQLAlchemy中ORM部分实现一个Mapper对象,将类的实例对应表中的记录,实例的属性对应字段。实现一个Data Mapping需要三个元素:Tabella Metadata, user-defined class, mapper对象,这三个是实现对象对表映射的基本元素,在此基础上,可实现一对多的映射,实现类似多表查询的问题
首先创建两个相关联的表Student, Score,表Score中以主表的id字段为外键

Student = Table('student', engine,  
              column(‘id', Interger, primary_key = True), 
              column('name', String, nullable=False), 
              column('age', Interger) 
) 
Score = Table('score', engine,  
            column('id', Integer, primary_key=True), 
            column('student_id', Integer, ForeignKey(student.id)) 
            column('category', String, nullable=False), 
            column('score', Integer)   
)

两表中,Score表以Student表中id项为外键,一般称Student表为主表,Score表为从表
表创建好后,那同样,在python中需定义两个与表相对应的类

class student_type(object): 
     def __init__(self): 
        self.name = None 
class score_type(object): 
     def __init__(self): 
        self.category = None

在建立mapping时,我们只需要体现两个表间又相互关联关系,
并不关心表中具体的主键与外键等关系(由SQLAlchemy处理),
当需要体现表student与表score间的关联关系,mapper具体的定义方法如:
mapper(student_type, student, properties={'_scores': relation(score_type, Score)})
通过properties中参数,实现score_type 与Score的映射,
由此可以通过访问student中的'_scores'属性来查询Score表中的值
另外,properties是一个字典,可以添加多个属性,SQLAlchemy中有些模块如backref, 也可导入

综上,使用关系映射可以方便地从一个对象直接找到相对应的其他的对象

Python 相关文章推荐
python正则表达式判断字符串是否是全部小写示例
Dec 25 Python
python获取当前计算机cpu数量的方法
Apr 18 Python
Python中函数eval和ast.literal_eval的区别详解
Aug 10 Python
python中获得当前目录和上级目录的实现方法
Oct 12 Python
Python绘制的二项分布概率图示例
Aug 22 Python
pygame游戏之旅 按钮上添加文字的方法
Nov 21 Python
详解python中的hashlib模块的使用
Apr 22 Python
使用Python和Prometheus跟踪天气的使用方法
May 06 Python
详解Python 多线程 Timer定时器/延迟执行、Event事件
Jun 27 Python
解决pyPdf和pyPdf2在合并pdf时出现异常的问题
Apr 03 Python
python程序需要编译吗
Jun 19 Python
python基于socket模拟实现ssh远程执行命令
Dec 05 Python
Python中的异常处理相关语句基础学习笔记
Jul 11 #Python
Python编写简单的HTML页面合并脚本
Jul 11 #Python
Python中super()函数简介及用法分享
Jul 11 #Python
Swift中的协议(protocol)学习教程
Jul 08 #Python
Python中多线程的创建及基本调用方法
Jul 08 #Python
使用PyInstaller将Python程序文件转换为可执行程序文件
Jul 08 #Python
Python遍历目录中的所有文件的方法
Jul 08 #Python
You might like
php 分库分表hash算法
2009/11/12 PHP
ThinkPHP 404页面的设置方法
2015/01/14 PHP
yii实现model添加默认值的方法(2种方法)
2016/01/06 PHP
为调试JavaScript添加输出窗口的代码
2010/02/07 Javascript
jQuery中使用data()方法读取HTML5自定义属性data-*实例
2014/04/11 Javascript
用简洁的jQuery方法toggleClass实现隔行换色
2014/10/22 Javascript
jQuery中parents()和parent()的区别分析
2014/10/28 Javascript
javascript制作坦克大战全纪录(1)
2014/11/27 Javascript
JavaScript中实现继承的三种方式和实例
2015/01/29 Javascript
基于jQuery实现仿51job城市选择功能实例代码
2016/03/02 Javascript
jQuery实现两个select控件的互移操作
2016/12/22 Javascript
使用Vue.js开发微信小程序开源框架mpvue解析
2018/03/20 Javascript
详细分析JavaScript中的深浅拷贝
2020/09/17 Javascript
[41:52]2018DOTA2亚洲邀请赛3月29日小组赛B组Effect VS Secret
2018/03/30 DOTA
linux系统使用python获取cpu信息脚本分享
2014/01/15 Python
使用Python编写提取日志中的中文的脚本的方法
2015/04/30 Python
浅谈Python数据类型之间的转换
2016/06/08 Python
Python实现的双色球生成功能示例
2017/12/18 Python
Python3.4 tkinter,PIL图片转换
2018/06/21 Python
Python面向对象之类的内置attr属性示例
2018/12/14 Python
python-pyinstaller、打包后获取路径的实例
2019/06/10 Python
Python列表倒序输出及其效率详解
2020/03/04 Python
Python多进程multiprocessing、进程池用法实例分析
2020/03/24 Python
Python3.7安装pyaudio教程解析
2020/07/24 Python
Python JSON常用编解码方法代码实例
2020/09/05 Python
html5 Canvas画图教程(8)—canvas里画曲线之bezierCurveTo方法
2013/01/09 HTML / CSS
接口可以包含哪些成员
2012/09/30 面试题
应届生文秘专业个人自荐信格式
2013/09/21 职场文书
中专生的个人自我评价
2013/12/11 职场文书
教师绩效考核方案
2014/01/21 职场文书
大队干部竞选演讲稿
2014/04/28 职场文书
高中生第一学年自我鉴定2015
2014/09/28 职场文书
2014年校长工作总结
2014/12/11 职场文书
2016秋季田径运动会广播稿
2015/12/21 职场文书
导游词之五台山
2019/10/11 职场文书
Vue如何清空对象
2022/03/03 Vue.js