一、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 MySQLdb模块连接操作mysql数据库实例,包括了Python MySQLdb模块连接操作mysql数据库实例的使用技巧和注意事项,需要的朋友参考一下 mysql是一个优秀的开源数据库,它现在的应用非常的广泛,因此很有必要简单的介绍一下用python操作mysql数据库的方法。python操作数据库需要安装一个第三方的模块,在http://mysql-python.
本文向大家介绍Java基于jdbc连接mysql数据库操作示例,包括了Java基于jdbc连接mysql数据库操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java基于jdbc连接mysql数据库操作。分享给大家供大家参考,具体如下: 用JDBC来连接数据库,基本步骤都大同小异,只不过不同的数据库之间的URL有些不同。其基本步骤可分为以下几点: 1、加载相应数据库的JDBC驱动程
本文向大家介绍nodejs基于mssql模块连接sqlserver数据库的简单封装操作示例,包括了nodejs基于mssql模块连接sqlserver数据库的简单封装操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了nodejs基于mssql模块连接sqlserver数据库的简单封装操作。分享给大家供大家参考,具体如下: 注意:开启sqlserver服务器允许远程连接的步骤,自行百度
本文向大家介绍MySQL 触发器的基础操作(六),包括了MySQL 触发器的基础操作(六)的使用技巧和注意事项,需要的朋友参考一下 1.为什么使用触发器: 在MySQL数据库中,数据库对象表是存储和操作数据的逻辑结构,而数据库对象触发器则用来实现由一些表事件触发的某个操作。在数据库系统中,当执行表事件时,则会激活触发器,从而执行器包含的操作。触发器的操作包含创建、查看、删除。
本文向大家介绍PDO操作MySQL的基础教程(推荐),包括了PDO操作MySQL的基础教程(推荐)的使用技巧和注意事项,需要的朋友参考一下 PHP中的PDO扩展为PHP访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。 PDO支持的PHP版本为PHP5.1以及更高的版本,而且在PHP5.2下PDO默认为开启状态
本文向大家介绍Python中的MongoDB基本操作:连接、查询实例,包括了Python中的MongoDB基本操作:连接、查询实例的使用技巧和注意事项,需要的朋友参考一下 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可护展的高性能数据存储解决方案。它的特点是高性能、易部署、易使用,存储数据非常方便。 MongoDB 简单使用 联接数据库 Connectio
本文向大家介绍MySQL视图原理与基本操作示例,包括了MySQL视图原理与基本操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了MySQL视图原理与基本操作。分享给大家供大家参考,具体如下: 概述 视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并在引用视
本节将回顾在Kafka集群上执行的最常见操作。所有在本节中看到的工具都可以在Kafka发行版的bin /目录下找到,如果没有参数运行,每个工具都会打印所有可能的命令行选项的细节。 添加和删除 topics您可以选择手动添加 topic ,或者在数据首次发布到不存在的 topic 时自动创建 topic 。如果 topic 是自动创建的,那么您可能需要调整用于自动创建 topic 的默认 topic