文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python orm框架SQLAlchemy简单应用(数据库操作)

2024-04-02 19:55

关注
#_*_coding:utf-8_*_
'''
创建SQLAlchemy应用基本过程
1、创建连接(和关系数据库创建连接)
2、声明映射文件(python中到类和数据库中的表做一对一的映射,这样就可以通过python中的类对数据库中到表进行操作)
3、创建模式(可以创建表)
4、初始化映射实例
5、创建会话
6、持久化实例对象
'''

from sqlalchemy import create_engine

#创建连接
engine = create_engine('mysql://root:1qaz#EDC@192.168.89.101:3306/student', echo=True)
'''
参数说明:
mysql 表示要连接的数据库是mysql数据库
root 表示用root账户登录mysql数据库
1qaz#EDC 表示连接数据库的root账户的密码
@ 是一个符号,规定的格式
192.168.89.1.101:3306 表示数据库的连接地址和端口3306
soms 表示将要连接的数据库的名字
echo=True 表示在执行的时候是否打印sql语句,False为不打印
'''


#声明映射文件
from sqlalchemy.ext.declarative import declarative_base #引入了declarative_base类
Base = declarative_base() #实例化了一个declarative_base实例

from sqlalchemy import Column, Integer, String #引入类Column, Integer, String类
class User(Base): #创建自己的实例类 名字为User 继承Base类
    __tablename__ = 'users' #这个属性,表示这个类和数据库中的users表进行映射
    id = Column(Integer, primary_key=True) #这个属性表示id在数据库表中代表着一列,Integer表示是整数,而且id是主键
    name = Column(String(10)) #这个属性表示在数据库表中也是一列,它的类型是string
    passwd = Column(String(10)) #这个属性表示在数据库表中也是一列,它的类型是string

    def __repr__(self): #定义了一个方法,目的是将User类更加形象的表示出来,没啥太大用途
        return "<User(name='%s', name='%s', password='%s')>" % (self.name, self.name, self.passwd)


#创建模式,创建数据库表,表名称:users
User.metadata.create_all(engine)

#创建会话(session)
'''创建会化'''
from sqlalchemy.orm import sessionmaker #引入sessionmaker这个函数
Session = sessionmaker(bind=engine) #创建session对话,通过这个session就可以对数据库进行一些操作
session = Session() #绑定

#持久化一个实例对象
ed_user = User(id=2,name='tantianran', passwd='1qaz#EDC') #向数据库表中到列插入数据
session.add(ed_user) #将这个实例添加到session中
session.commit() #提交


执行结果:

python orm框架SQLAlchemy简单应用(数据库操作)

python orm框架SQLAlchemy简单应用(数据库操作)


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯