Python SQLAlchemy 模块
SQLAlchemy 简介:
SQLAlchemy 是用于实现 ORM(Object Relational Mapping,对象关系映射)的一个模块,即把数据库的表结构映射到对象上
在 Python 中,也就是将关系型数据库表结构抽象成面向对象的 Python 类,将表操作转换成类操作,避免了复杂的 SQL 语句编写
[root@localhost ~]# pip3 install SQLAlchemy
SQLAlchemy 连接数据库:
#!/usr/bin/env python3
#-*- coding: utf- -*- from sqlalchemy import create_engine engine = create_engine('mysql+pymysql://root:123456@127.0.0.1/test', encoding='utf8', echo=True)
print(engine) # create_engine():用于创建一个Engine实例,通过这个实例,SQL语句会被解释成Python类方法
# 语法:mysql+pymysql://<user>:<password>@<host>[:<port>]/<dbname>
# mysql:表示使用哪种数据库,其他数据库如 Oracle 、Redis 、MongoDB 等
# pymysql:SQLAlchemy本身无法操作数据库,必须使用第三方模块进行操作
python2 使用 mysql+mysqldb://<user>:<password>@<host>[:<port>]/<dbname> 来操作数据库
python3 使用 mysql+pymysql://<user>:<password>@<host>[:<port>]/<dbname> 来操作数据库
# <user>:<password>@<host>[:<port>]/<dbname>:分别表示连接数据库的用户名 、密码 、主机以及连接到哪个库名
# encoding='utf8':用于指定字符编码,可选参数
# echo=True:会显示Python类对应的SQL语句,方便查看要执行什么SQL语句,可选参数
SQLAlchemy 创建表结构:
第一种方式:在自定义的类中继承 declarative_base 这个基类来映射数据表
#!/usr/bin/env python3
#-*- coding: utf-8 -*- from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, String, Integer engine = create_engine('mysql+pymysql://root:123456@127.0.0.1/test') # 连接数据库
Base = declarative_base() # 生成 ORM 基类 class User(Base): # 继承基类
__tablename__ = "user" # 定义表名
userid = Column(Integer, primary_key=True) # 定义 userid 字段,字段类型为数值类型,并设为主键
username = Column(String(32)) # 定义 username 字段,字段类型为字符串类型
password = Column(String(64)) # 定义 password 字段,字段类型为字符串类型 if __name__ == '__main__':
Base.metadata.create_all(engine) # 创建表结构,父类Base会调用所有继承他的子类来创建表结构
第二种方式:通过 MetaData 来存储表的元数据(也就是存储表结构),然后映射数据表
#!/usr/bin/env python3
#-*- coding: utf-8 -*- from sqlalchemy import create_engine, MetaData
from sqlalchemy import Table, Column, Integer, String engine = create_engine('mysql+pymysql://root:123456@127.0.0.1/test') # 连接数据库
metadata = MetaData() # 存储表的元数据 user = Table('user', metadata, # 定义表名
Column('userid', Integer, primary_key=True), # 定义 userid 字段,字段类型为数值类型,并设为主键
Column('username', String(32)), # 定义 username 字段,字段类型为字符串类型
Column('password', String(64)), # 定义 password 字段,字段类型为字符串类型
) if __name__ == '__main__':
metadata.create_all(engine) # 创建表结构
SQLAlchemy 增加表数据:
Python 对 MySQL 数据库进行增删查改等操作需要先创建 session,session 用于创建程序与数据库之间的会话,所有对象的载入和保存都需要通过 session 对象
#!/usr/bin/env python3
#-*- coding: utf-8 -*- from sqlalchemy import create_engine
from sqlalchemy import Column, String, Integer
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker engine = create_engine('mysql+pymysql://root:123456@127.0.0.1/test')
Base = declarative_base()
DBSession = sessionmaker(bind=engine) # 创建与数据库的会话
session = DBSession() # 实例化与数据库的会话 class User(Base):
__tablename__ = "user"
userid = Column(Integer, primary_key=True)
username = Column(String(32))
password = Column(String(64)) user1 = User(userid=1, username='Tom', password='') # 生成user表要插入的一条数据
user2 = User(userid=2, username='John', password='') # 生成user表要插入的一条数据
user3 = User(userid=3, username='Jeny', password='') # 生成user表要插入的一条数据 session.add(user1) # add()用于把user表要插入的一条数据添加到Session里
session.add_all([user2, user3]) # add_all()用于把user表要插入的多条数据添加到Session里
session.commit() # 最后提交会话,实现插入数据
session.close()
SQLAlchemy 查询表数据:
Python SQLAlchemy 模块的更多相关文章
- python数据库操作之pymysql模块和sqlalchemy模块(项目必备)
pymysql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同. 1.下载安装 pip3 install pymysql 2.操作数据库 (1).执行sql #! ...
- python使用SQLAlchemy模块连接MySQL
ORM技术:Object-Relational Mapping,负责把关系数据库的表结构映射到对象上. 1.安装SQLAlchemy,MySQLdb模块 MySQLdb安装教程:http://www. ...
- Python(SQLAlchemy-ORM)模块之mysql操作
一.SQLAlchemy简单介绍 SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数 ...
- python 常用模块(转载)
转载地址:http://codeweblog.com/python-%e5%b8%b8%e7%94%a8%e6%a8%a1%e5%9d%97/ adodb:我们领导推荐的数据库连接组件bsddb3:B ...
- Python标准模块--importlib
作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 1 模块简介 Python提供了importlib包作为标准库的一 ...
- python+SQLAlchemy+爬虫
python+SQLAlchemy+爬虫 前面分享了SQLAlchemy的知识,这次我共享一下学习用python开发爬虫再把爬出来的数据放到用SQLAlchemy的数据库上面的知识,当然我这个是带测试 ...
- Python SQLalchemy的学习与使用
SQLAlchemy是python中最著名的ORM(Object Relationship Mapping)框架了. 前言:什么是ORM? ORM操作是所有完整软件中后端处理最重要的一部分,主要完成了 ...
- 【转】Python标准模块--importlib
[转]Python标准模块--importlib 作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 1 模块简介 P ...
- SQLAlchemy模块的使用教程
数据库表是一个二维表,包含多行多列.把一个表的内容用Python的数据结构表示出来的话,可以用一个list表示多行,list的每一个元素是tuple,表示一行记录,比如,包含id和name的user表 ...
随机推荐
- dp之多维背包hdu2159
二维背包问题,我是觉得这个题目数据比较水,虽然它最后说了怪可以无限个,但是它却只能最多杀s个,也就是所有品种的怪最多为s个,那么就是二维完全背包的问题了.......同时,它没有说一定要杀s只怪,所以 ...
- VBA学习笔记(4)--数组和单元格互相转换
说明(2017.3.23): 1. VBA的数组还是很难用的,其实就是非常难用! 2. 要先定义一个数组,可以是空的,也可以里面写个数字作为数组长度. 3. 如果是空数组,可以后面redim重新定义数 ...
- 一款纯css3实现的颜色渐变按钮
之前为大家分享了推荐10款纯css3实现的实用按钮,今天给大家带来一款纯css3实现的颜色渐变按钮.这款按钮的边框和文字的颜色通过css3实现两种颜色的渐变,效果非常好看,一起看下效果图: 在线预览 ...
- rabbitmq系列(一)-基本概念理解
1.简介 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue protocol)的开源实现.AMQP高级消息队列,说白了就是一个开源的消息中间件.它能解决 ...
- Linux kernel 找到gpio被占用位置
一开始是通过断点 printk看哪里申请这个GPIO正常哪里不正常,发现这种方法太繁琐. 经过同事提醒,直接在 drivers/gpio/gpiolib.c 里面的 gpio_request 里面添加 ...
- Ajax-ajax实例3-动态树形列表
项目结构: 项目演示: 技术要点: 1.3.2 技术要点在基本原理的介绍中,了解到通过在父节点内动态创建子节点,并利用样式表缩进完成树形列表的基本框架.除了这一点外,还有下面一些问题需要考虑.1 .将 ...
- Ubuntu安装MediaInfo
Ubuntu版 打包下载:艺搜下载 适用于Ubuntu 12.10(i386) 安装libzen0_v0.4.29 _i386.xUbuntu_12.10.deb 安装libmediainfo0_v0 ...
- Linux Tcl和Expect的安装
一.先安装Tcl 1.下载:tcl版本 8.4.19 http://sourceforge.net/projects/tcl/files/Tcl/8.4.19/tcl8.4.19-src.tar.gz ...
- Ubuntu之Docker安装
1.添加官方的GPG key到系统 curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - 2.添加D ...
- 第三百一十五节,Django框架,CSRF跨站请求伪造
第三百一十五节,Django框架,CSRF跨站请求伪造 全局CSRF 如果要启用防止CSRF跨站请求伪造,就需要在中间件开启CSRF #中间件 MIDDLEWARE = [ 'django.midd ...