初学sqlalchemy操作MySql

初学sqlalchemy

这两天一直在研究python对mysql的连接

1. ORM模型

ORM 全称 Object Relational Mapping, 翻译过来叫 对象关系映射 。简单的说,ORM 将数据库中的表与面向对象语言中的类建立了一种对应关系。这样,我们要操作数据库,数据库中的表或者表中的一条记录就可以直接通过操作类或者类实例来完成。

2. 对应关系的理解
数据表面向对象
一张表一个类
实例对象表的一条数据

如果上标没看懂请看下图
在这里插入图片描述

想要实现 MySQL 数据表到 Python 类的映射 就要应用ORM模型中的sqlalchemy

安装 sqlalchemy 用到以下 cmd 命令:

pip install sqlalchemy

在使用之前必须拥有 mysql 的驱动 安装 mysql 驱动命令如下:

pip install pymysql

2.1引擎
from sqlalchemy import create_engine
engine = create_engine('mysql+pymysql//user:password@127.0.0.1:3306/study?
charset=utf8')
# 引擎创建
create_engine('数据库类型+驱动//用户名:密码@IP地址:端口/数据表?编码格式')
2.2 基类
from sqlalchemy.ext.declarative import declarative_base
# 创建基类时加入引擎
Base = declarative_base(engine)
3 整体操作
整体操作就是一套连招QWER一起按 (结束战斗)
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, String, Integer

# 创建引擎
engine = create_engine('mysql+pymysql//xxx:xxxxx@127.0.0.1:3306/xxx?
charset=utf8')
# 创建基类
Base = declarative_base(engine)

class User(Base):
"""创建的类继承自基类Base"""
	# 创建表的名称
	__tablename__ = 'user'
	# 创建字段
	id = Column(Integer, primary_key=True)
	name = Column(String(64), unique=True, nullable=False)
    email = Column(String(64), unique=True)
	
	def __repr__(self):
		return f'{self.name}'
	
if __name__ == __main__ :
	# 创建数据表
	Base.metadata.create_all()
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值