python安装orm_Python之ORM框架SQLAlchemy

cefe6ac69e1dcbbcada724a73d77ad40.png

一、SQLAlchemy简介

SQLAlchemy是Python SQL工具包和对象关系映射器,是python中最著名的ORM(Object Relationship Mapping)框架,它简化了应用程序开发人员在原生SQL上的操作,使开发人员将主要精力都放在程序逻辑上,从而提高开发效率。它提供了一整套著名的企业级持久性模式,设计用于高效和高性能的数据库访问。

使用ORM操作数据库:

优势 :代码易读,隐藏底层原生SQL语句,提高了开发效率。

劣势 :执行效率低 ,将方法转换为原生SQL后 原生SQL不一定是最优的。

环境:

Windows 7  x64   python 3.7.1  SQLAlchemy 1.3.5   pymysql 0.9.3    mysqld  5.6.43

关于如何安装上述环境,这里不做演示,相信大家能搜到这篇文章,想必这种小问题不在话下。

二、简单的操作

1、准备数据库sql_demomysql> create database sql_demo;

2、在sql_demo中创建表from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# 创建数据库引擎

engine = create_engine('mysql+pymysql://数据库用户:数据库密码@127.0.0.1:3306/数据库名?charset=utf8')

# 创建表

Base.metadata.create_all(engine)

运行上面的代码后会在数据库sql_demo中创建一个名为sqldemo的表。

6ca3b0b8b382299738cca072d7bfe4f8.png

3、向表中添加数据。from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# 创建数据库引擎

engine = create_engine('mysql+pymysql://root:123@127.0.0.1:3306/sql_demo?charset=utf8')

# 创建表

# Base.metadata.create_all(engine)

# 向表中添加数据

obj = SQLDemo(name='小明')

# 创建会话

obj_session = sessionmaker(engine)

# 打开会话

db_session = obj_session()

# 向表中添加数据,此时数据保存在内存中

db_session.add(obj)

# 提交数据,将数据保存到数据库中

db_session.commit()

# 关闭会话

db_session.close()

相关推荐:《Python相关教程》

3.1向表中添加多条数据。

向表中添加多条数据

添加后的数据如下:

fc637e79f405d663adfa33ed77ffbb66.png

4、查询表中数据from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# # 创建数据库引擎

engine = create_engine('mysql+pymysql://root:123@127.0.0.1:3306/sql_demo?charset=utf8')

# 创建会话

obj_session = sessionmaker(engine)

# 打开会话

db_session = obj_session()

# 查询表中所有数据

all_list = db_session.query(SQLDemo).all()

for obj in all_list:

print(obj.id,obj.name)

# 提交数据,将数据保存到数据库中

db_session.commit()

# 关闭会话

db_session.close()

最终打印结果如下:

a428cc251f296e0b0ae2f277bb436bc0.png

4.1使用filter过滤查询条件from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# # 创建数据库引擎

engine = create_engine('mysql+pymysql://root:123@127.0.0.1:3306/sql_demo?charset=utf8')

# 创建会话

obj_session = sessionmaker(engine)

# 打开会话

db_session = obj_session()

# 使用filter过滤查询条件

all_list = db_session.query(SQLDemo).filter(SQLDemo.name=='小明')

for obj in all_list:

print(obj.id,obj.name)

# 提交数据,将数据保存到数据库中

db_session.commit()

# 关闭会话

0124c5ef40bedd46160d5901ecdef100.png

5、修改数据from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# 创建数据库引擎

engine = create_engine('mysql+pymysql://root:123@127.0.0.1:3306/sql_demo?charset=utf8')

# 创建会话

obj_session = sessionmaker(engine)

# 打开会话

db_session = obj_session()

# 更改id是2的name为娃哈哈

all_list = db_session.query(SQLDemo).filter(SQLDemo.id==2).update({'name':'娃哈哈'})

# 提交数据,将数据保存到数据库中

db_session.commit()

# 关闭会话

db_session.close()

6、删除数据from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy import Column, Integer, String

from sqlalchemy import create_engine

from sqlalchemy.orm import sessionmaker

Base = declarative_base()  # 导出官方基础类

class SQLDemo(Base):

__tablename__ = 'SqlDemo'  # 表名

# 创建字段

id = Column(Integer,primary_key=True,autoincrement=True)

name = Column(String(32))

# # 创建数据库引擎

engine = create_engine('mysql+pymysql://root:123@127.0.0.1:3306/sql_demo?charset=utf8')

# 创建会话

obj_session = sessionmaker(engine)

# 打开会话

db_session = obj_session()

# 删除id是2的行

all_list = db_session.query(SQLDemo).filter(SQLDemo.id==2).delete()

# 提交数据,将数据保存到数据库中

db_session.commit()

# 关闭会话

db_session.close()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值