zoukankan      html  css  js  c++  java
  • SQLAlchemy增删改查 一对多 多对多

    今天来聊一聊Python的ORM框架SQLAlchemy 有些同学已经听说过这个框架的大名了,也听说了SQLAlchemy没有Django的Models好用

    1 创建数据表

    create_table.py

    # 1 导入基础模型
    from sqlalchemy.ext.declarative import declarative_base
    
    #2 创建ORM模型基类  实例化模型
    Base = declarative_base()
    
    #3 导入ORM对应数据库数据类型的字段
    from sqlalchemy import Column,Integer,String
    
    #4 创建ORM对象   # 当前的这个Object继承了Base也就是代表了Object继承了ORM的模型
    class User(Base):   # 相当于 Django Models中的 Model
        # 为Table创建名称
        __tablename__ = "user"
        id = Column(Integer,primary_key=True,autoincrement=True)
        name = Column(String(32),index = True)
    
    # 5 创建数据库连接
    from sqlalchemy import create_engine
    #注意 root后面的空白处填写密码
    engine = create_engine("mysql+pymysql://root:@127.0.0.1:3306/sqla?charset=utf8")
    #数据库连接创建完成
    
    
    
    #6 去数据库中创建与User所对应的数据表
    #去engine数据库中创建所有继承Base类的ORM对象     
    # Base 自动检索所有继承Base的ORM 对象 并且创建所有的数据表 Base.metadata.create_all(engine)

    2 增删改查操作

    2.1 增加数据

    #增加数据
    #1 创建数据库连接
    from create_table import engine
    
    #2 创建会话 ---打开数据库连接
    
    from sqlalchemy.orm import sessionmaker
    
    #3 创建回话窗口
    Session = sessionmaker(engine)
    
    # 4打开回话窗口
    db_session = Session()
    
    #单条数据的增加
    # #1 导入  首先导入之间做好的ORM 对象 User
    # from create_table import User
    #
    # #2 增加数据 add只能放一个对象 而add_all 里面放一个列表 也就是多个对象
    # user_obj = User(name='mlh')
    # db_session.add(user_obj)  #相当于Insert into
    #
    # #3 执行会话中的所有操作
    # db_session.commit()
    #
    # #4 关闭会话
    # db_session.close()
    
    
    #批量增加
    # from create_table import User
    #
    # db_session.add_all({
    #     User(name='猪猪'),
    #     User(name='花花'),
    #     User(name='乖乖'),
    # })
    #
    # db_session.commit()
    # db_session.close()
    
    
    #扩展  db_session可同时执行多条语句
    from create_table import User
    user1 = User(name='lala')
    user2 = User(name='dada')
    user3 = User(name='tata')
    
    db_session.add(user1)
    db_session.add(user2)
    db_session.add(user3)
    #这里的知识点就是db_session支持多条语句同时执行
    db_session.commit()
    db_session.close()
    

    2.2 查询数据

    #查询数据
    #会话窗口
    from sqlalchemy.orm import sessionmaker
    from create_table import engine
    #1 创建窗口
    Session = sessionmaker(engine)
    #2 打开回话窗口
    db_session = Session()
    
    # 1 简单查询
    # select * from table
    
    from create_table import User
    #查询出User表中的所有数据
    
    #注意 要是后面没有.all()  则打印出来的是一个sql语句  将所有的数据序列化成
    # user_sql = db_session.query(User)
    # print(user_sql)   #结果是
                      #SELECT user.id AS user_id, user.name AS user_name
                      # FROM user
    
    #注意.all()返回的是列表
    # user_list = db_session.query(User).all()
    # print(user_list) #这是一个列表
    #
    #
    # for row in user_list:
    #     print(row.id,row.name)
    #6 dada
    #5 lala
    #1 mlh
    #7 tata
    #4 乖乖
    #2 猪猪
    #3 花花
    
    #查询第一条数据
    # user = db_session.query(User).first()
    # print(user.id,user.name)
    
    
    
    #带条件的查询
    #方式一 filter
    # user_a = db_session.query(User).filter(User.id == 4).all()
    # print(user_a[0].id,user_a[0].name)
    
    
    # 方式二 filter_by
    # user_a = db_session.query(User).filter_by(id=4).first()
    # print(user_a.id,user_a.name)
    
    #
    # user_list = db_session.query(User).filter(User.id >= 4).all()
    # for row in user_list:
    #     print(row.id,row.name)
    
    
    #扩展 查看sql语句
    user_sql = db_session.query(User).filter(User.id >= 4)
    print(user_sql)
    
    #结果是 SELECT user.id AS user_id, user.name AS user_name FROM user WHERE user.id >= %(id_1)s
    

    2.3 修改数据

    #更新修改数据
    from create_table import engine,User
    from sqlalchemy.orm import sessionmaker
    
    # 1 创建会话窗口
    Session = sessionmaker(engine)
    # 2 打开会话窗口
    db_session = Session()
    
    #修改数据 (首先要查存出要修改的数据)
    #sql语句  update 'user' set 'name' = '666' where id =1
    # user_up = db_session.query(User).filter(User.name == "mlh").update({'name':'佩奇'})
    # print(user_up)  #打印出来的是受影响的行数  为1
    #
    # db_session.commit()
    # db_session.close()
    
    
    # 符合条件 就修改  这里有多个
    user_up = db_session.query(User).filter(User.id >= 5).update({'name':'小猪佩奇'})
    print(user_up)  #打印出来的是受影响的行数  为3
    db_session.commit()
    db_session.close()
    
    
    
    # commit 提交操作 除了查询 增加修改删除都要commit()操作
    

    2.4 删除数据

    from sqlalchemy.orm import sessionmaker
    from create_table import engine,User
    
    #1 创建会话窗口
    Session = sessionmaker(engine)
    
    #2 打开会话窗口
    db_session = Session()
    
    
    #删除操作  首先要查询出要删除的数据
    #sql语句 delete from user where id=5
    #删除一条数据
    # user_del = db_session.query(User).filter(User.id==5).delete()
    # print(user_del)
    #
    # db_session.commit()
    # db_session.close()
    
    #删除多条数据
    # user_del = db_session.query(User).filter(User.id >= 5).delete()
    # print(user_del)
    # db_session.commit()
    # db_session.close()
    
    #
    

    2.5 高级版查询操作

    #老规矩
    from create_table import User,engine
    from sqlalchemy.orm import sessionmaker
    
    Session = sessionmaker(engine)
    db_session = Session()
    
    # 查询数据表操作
    # and or
    from sqlalchemy.sql import and_ , or_
    ret = db_session.query(User).filter(and_(User.id > 3, User.name == '乖乖')).all()
    ret = db_session.query(User).filter(or_(User.id < 2, User.name == '乖乖')).all()
    
    # 查询所有数据
    r1 = db_session.query(User).all()
    
    # 查询数据 指定查询数据列 加入别名
    r2 = db_session.query(User.name.label('username'), User.id).first()
    print(r2.id,r2.username) # 15 NBDragon
    
    # 表达式筛选条件
    r3 = db_session.query(User).filter(User.name == "乖乖").all()
    
    # 原生SQL筛选条件
    r4 = db_session.query(User).filter_by(name='乖乖').all()
    r5 = db_session.query(User).filter_by(name='乖乖').first()
    
    # 字符串匹配方式筛选条件 并使用 order_by进行排序
    r6 = db_session.query(User).filter(text("id<:value and name=:name")).params(value=224, name='乖乖').order_by(User.id).all()
    
    #原生SQL查询
    r7 = db_session.query(User).from_statement(text("SELECT * FROM User where name=:name")).params(name='乖乖').all()
    
    # 筛选查询列
    # query的时候我们不在使用User ORM对象,而是使用User.name来对内容进行选取
    user_list = db_session.query(User.name).all()
    print(user_list)
    for row in user_list:
        print(row.name)
    
    # 别名映射  name as nick
    user_list = db_session.query(User.name.label("nick")).all()
    print(user_list)
    for row in user_list:
        print(row.nick) # 这里要写别名了
    
    # 筛选条件格式
    user_list = db_session.query(User).filter(User.name == "乖乖").all()
    user_list = db_session.query(User).filter(User.name == "乖乖").first()
    user_list = db_session.query(User).filter_by(name="乖乖").first()
    for row in user_list:
        print(row.nick)
    
    # 复杂查询
    from sqlalchemy.sql import text
    user_list = db_session.query(User).filter(text("id<:value and name=:name")).params(value=3,name="乖乖")
    
    # 查询语句
    from sqlalchemy.sql import text
    user_list = db_session.query(User).filter(text("select * from User id<:value and name=:name")).params(value=3,name="乖乖")
    
    # 排序 :
    user_list = db_session.query(User).order_by(User.id).all()
    user_list = db_session.query(User).order_by(User.id.desc()).all()
    for row in user_list:
        print(row.name,row.id)
    
    #其他查询条件
    """
    ret = session.query(User).filter_by(name='乖乖').all()
    ret = session.query(User).filter(User.id > 1, User.name == '乖乖').all()
    ret = session.query(User).filter(User.id.between(1, 3), User.name == '乖乖').all() # between 大于1小于3的
    ret = session.query(User).filter(User.id.in_([1,3,4])).all() # in_([1,3,4]) 只查询id等于1,3,4的
    ret = session.query(User).filter(~User.id.in_([1,3,4])).all() # ~xxxx.in_([1,3,4]) 查询不等于1,3,4的
    ret = session.query(User).filter(User.id.in_(session.query(User.id).filter_by(name='乖乖'))).all() 子查询
    from sqlalchemy import and_, or_
    ret = session.query(User).filter(and_(User.id > 3, User.name == '乖乖')).all()
    ret = session.query(User).filter(or_(User.id < 2, User.name == '乖乖')).all()
    ret = session.query(User).filter(
        or_(
            User.id < 2,
            and_(User.name == 'eric', User.id > 3),
            User.extra != ""
        )).all()
    # select * from User where id<2 or (name="eric" and id>3) or extra != "" 
    
    # 通配符
    ret = db_session.query(User).filter(User.name.like('e%')).all()
    ret = db_session.query(User).filter(~User.name.like('e%')).all()
    
    # 限制
    ret = db_session.query(User)[1:2]
    
    # 排序
    ret = db_session.query(User).order_by(User.name.desc()).all()
    ret = db_session.query(User).order_by(User.name.desc(), User.id.asc()).all()
    
    # 分组
    from sqlalchemy.sql import func
    
    ret = db_session.query(User).group_by(User.extra).all()
    ret = db_session.query(
        func.max(User.id),
        func.sum(User.id),
        func.min(User.id)).group_by(User.name).all()
    
    ret = db_session.query(
        func.max(User.id),
        func.sum(User.id),
        func.min(User.id)).group_by(User.name).having(func.min(User.id) >2).all()
    """
    
    # 关闭连接
    db_session.close()
    
    orm_select_more
    

    2.6 高级修改数据操作

    #高级版更新操作
    from create_table import User,engine
    from sqlalchemy.orm import sessionmaker
    
    Session = sessionmaker(engine)
    db_session = Session()
    
    #直接修改
    db_session.query(User).filter(User.id > 0).update({"name" : "099"})
    
    #在原有值基础上添加 - 1
    db_session.query(User).filter(User.id > 0).update({User.name: User.name + "099"}, synchronize_session=False)
    
    #在原有值基础上添加 - 2
    db_session.query(User).filter(User.id > 0).update({"age": User.age + 1}, synchronize_session="evaluate")
    db_session.commit()
    
    orm_update_more
    

    3 一对多的操作:ForeignKey

    3.1 创建数据表及其关系relationship:

    create_table_ForeignKey.py

    #一对多建表操作
    
    from sqlalchemy.ext.declarative import declarative_base
    Base = declarative_base()
    
    from sqlalchemy import Column,Integer,String,ForeignKey
    from sqlalchemy.orm import relationship
    
    class Student(Base):
        __tablename__ = "student"
        id = Column(Integer,primary_key=True,autoincrement=True)
        name = Column(String(32))
        school_id = Column(Integer,ForeignKey("school.id"))
    
        stu2sch = relationship("School",backref="sch2stu")
    
    
    
    
    class School(Base):
        __tablename__ = "school"
        id = Column(Integer, primary_key=True, autoincrement=True)
        name = Column(String(32))
    
    
    from sqlalchemy import create_engine
    engine = create_engine("mysql+pymysql://root:@127.0.0.1:3306/sqla?charset=utf8")
    
    Base.metadata.create_all(engine)
    

     3.2 基于relationship增加数据

    from sqlalchemy.orm import sessionmaker
    from create_table_ForeignKey import engine,Student,School
    
    #1 创建会话窗口
    Session = sessionmaker(engine)
    
    #2 打开会话窗口
    db_session = Session()
    
    # 3增加操作  添加数据
    # sch_obj = School(name="oldboybeijing")
    # db_session.add(sch_obj)
    # db_session.commit()
    
    #然后查询出刚刚添加的学校信息 在这个学校中添加相应的学生信息
    # sch = db_session.query(School).filter(School.name=="oldboybeijing").first()
    # stu_obj = Student(name='猪猪',school_id=sch.id)
    # db_session.add(stu_obj)
    # db_session.commit()
    # db_session.close()
    
    #2 正向添加数据
    stu_obj = Student(name='哒哒',stu2sch=School(name='oldboyshengzheng'))
    db_session.add(stu_obj)
    db_session.commit()
    db_session.close()
    
    
    #3 添加数据relationship版  反向添加
    # sch_obj = School(name='oldboyshanghai')
    # sch_obj.sch2stu = [Student(name='乖乖'),Student(name='哈哈')]
    # db_session.add(sch_obj)
    # db_session.commit()
    # db_session.close()
    

    3.3 基于relationship查询数据

    from sqlalchemy.orm import sessionmaker
    from create_table_ForeignKey import engine,Student,School
    
    #1 创建会话窗口
    Session = sessionmaker(engine)
    
    #2 打开会话窗口
    db_session = Session()
    
    
    #查询数据 relationship版 正向查询数据
    stu_obj = db_session.query(Student).all()
    print(stu_obj)
    
    for row in stu_obj:
        print(row.id,row.name,row.school_id,row.stu2sch.name)
    
    
    
    
    # 反向查询数据
    sch_obj = db_session.query(School).all()
    for school in sch_obj:
        for student in school.sch2stu:
            print(school.id,school.name,student.name)
    

    3.4 修改数据

    from sqlalchemy.orm import sessionmaker
    from create_table_ForeignKey import engine,Student,School
    
    #1 创建会话窗口
    Session = sessionmaker(engine)
    
    #2 打开会话窗口
    db_session = Session()
    
    # 修改数据
    sch = db_session.query(School).filter(School.name=="oldboyshanghai").first()
    db_session.query(Student).filter(Student.name=='哒哒').update({'school_id':sch.id})
    db_session.commit()
    db_session.close()
    

    3.5 删除数据

    from sqlalchemy.orm import sessionmaker
    from create_table_ForeignKey import engine,Student,School
    
    #1 创建会话窗口
    Session = sessionmaker(engine)
    
    #2 打开会话窗口
    db_session = Session()
    
    #删除数据
    
    sch = db_session.query(School).filter(School.name=='oldboyshanghai').first()
    db_session.query(Student).filter(Student.school_id == sch.id).delete()
    db_session.commit()
    db_session.close()
    

     

    4 多对多:ManyToMany

    4.1创建表基关系

    create_table_many.py

    from sqlalchemy.ext.declarative import declarative_base
    
    Base = declarative_base()
    
    from sqlalchemy.orm import relationship
    from sqlalchemy import Column,Integer,String,ForeignKey
    
    
    class Hotel(Base):
        __tablename__ ="hotel"
        id = Column(Integer,primary_key=True)
        girl_id =Column(Integer,ForeignKey('girl.id'))
        boy_id =Column(Integer,ForeignKey('boy.id'))
    
    
    class Girl(Base):
        __tablename__ = "girl"
        id =Column(Integer,primary_key=True)
        name= Column(String(32),index=True)
        #创建关系   
        boys = relationship("Boy",secondary ="hotel",backref = "girl2boy")
    
    
    class Boy(Base):
        __tablename__="boy"
        id = Column(Integer,primary_key = True)
        name = Column(String(32),index=True)
    
    
    
    from sqlalchemy import create_engine
    engine = create_engine("mysql+pymysql://root@127.0.0.1:3306/sqla?charset=utf8")
    
    Base.metadata.create_all(engine)
    

    curd_insert_many.py

    from create_table_many import engine,Hotel,Girl,Boy
    from sqlalchemy.orm import sessionmaker
    
    #1 创建窗口
    Session = sessionmaker(engine)
    db_session = Session()
    
    
    # 1 通过Girl添加Boy和Hotel数据 正向查询
    girl = Girl(name='姗姗')
    girl.boys =[Boy(name='吖吖')]
    db_session.commit()
    db_session.close()
    
    
    
    #2 通过Boy添加Girl数据   反向添加数据
    boy = Boy(name="哈哈")
    boy.girl2boy = [Girl(name="照照"),Girl(name="滴滴")]
    db_session.add(boy)
    db_session.commit()
    db_session.close()
    
    from create_table_many import engine,Boy,Girl,Hotel
    from sqlalchemy.orm import sessionmaker
    
    Session = sessionmaker(engine)
    db_session = Session()
    
    #1 查询数据
    1.通过Boy查询约会过的所有Girl
    hotel = db_session.query(Boy).all()
    for row in hotel:
        for row2 in row.girl2boy:
            print(row.name,row2.name)
    
    1.通过Girl查询约会过的所有Boy
    hotel = db_session.query(Girl).all()
    for row in hotel:
        for row2 in row.boys:
            print(row.name,row2.name)
            
    
  • 相关阅读:
    使用 EasyBCD 安装Ubuntu 14.04 Error 15: file not found错误的解决方法
    浅谈程序猿的职业规划,看你如何决定自己的未来吧。
    [转载]DOS循环:bat/批处理for命令详解 (史上虽详尽的总结和说明~~)
    bat 批处理 字符串 截取
    window上使用GIT的个人经验(入门级)
    Android 访问 wcf
    解决 MyEclipse 10 中 JSp页面 “return false” 报错问题
    微信公共平台(码农在努力)
    Spring Cloud 中使用 Zipkin 追踪服务
    Spring Cloud Config 分布式配置中心
  • 原文地址:https://www.cnblogs.com/mlhz/p/10396097.html
Copyright © 2011-2022 走看看