热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

#1.导入模块fromsqlalchemyimport*fromsqlclchemy.ormimport*#2.建立数据库引擎mysql_enginecreate_engine(

# 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, 也可导入

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



推荐阅读
  • 关于进程的复习:#管道#数据的共享Managerdictlist#进程池#cpu个数1#retmap(func,iterable)#异步自带close和join#所有 ... [详细]
  • 整理于2020年10月下旬:总结过去,展望未来Itistoughtodayandtomorrowwillbetougher.butthedayaftertomorrowisbeau ... [详细]
  • mybatis 详解(七)一对一、一对多、多对多
    mybatis详解(七)------一 ... [详细]
  • MySQL 5.7 服务端在 Windows 上的安装与配置
    本文详细介绍了在 Windows 系统上安装和配置 MySQL 5.7 服务端的方法,包括 my.ini 配置文件的设置、初始化数据库、启动服务以及设置用户权限等步骤。 ... [详细]
  • iOS snow animation
    CTSnowAnimationView.hCTMyCtripCreatedbyalexon1614.Copyright©2016年ctrip.Allrightsreserved.# ... [详细]
  • 本文介绍了 Go 语言中的高性能、可扩展、轻量级 Web 框架 Echo。Echo 框架简单易用,仅需几行代码即可启动一个高性能 HTTP 服务。 ... [详细]
  • 本文详细介绍了 PHP 中对象的生命周期、内存管理和魔术方法的使用,包括对象的自动销毁、析构函数的作用以及各种魔术方法的具体应用场景。 ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 驱动程序的基本结构1、Windows驱动程序中重要的数据结构1.1、驱动对象(DRIVER_OBJECT)每个驱动程序会有唯一的驱动对象与之对应,并且这个驱动对象是在驱 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • h5调用本地摄像头和麦克风一
    h5调用本地摄像头和麦克风一,Go语言社区,Golang程序员人脉社 ... [详细]
  • iOS 不定参数 详解 ... [详细]
  • python模块之正则
    re模块可以读懂你写的正则表达式根据你写的表达式去执行任务用re去操作正则正则表达式使用一些规则来检测一些字符串是否符合个人要求,从一段字符串中找到符合要求的内容。在 ... [详细]
  • 在深入掌握Spring框架的事务管理之前,了解其背后的数据库事务基础至关重要。Spring的事务管理功能虽然强大且灵活,但其核心依赖于数据库自身的事务处理机制。因此,熟悉数据库事务的基本概念和特性是必不可少的。这包括事务的ACID属性、隔离级别以及常见的事务管理策略等。通过这些基础知识的学习,可以更好地理解和应用Spring中的事务管理配置。 ... [详细]
author-avatar
xiaoge
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有