关联型数据表的增删改查与过滤器查询

本文详细介绍了在关联型数据表中如何进行增删改查操作,并重点探讨了查询过滤器的使用,同时总结了SQLAlchemy执行函数的应用及分页对象的属性和方法。
摘要由CSDN通过智能技术生成

关联型数据表的增删改查与过滤器查询

from datetime import datetime
from flask import Flask, render_template
from flask_sqlalchemy import SQLAlchemy, Pagination
from flask_bootstrap import Bootstrap
import pymysql
pymysql.install_as_MySQLdb()
from sqlalchemy import desc, func

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:westos@localhost/UserTest'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db = SQLAlchemy(app)

#### 用户和角色是什么关系?
# - 一对一
# - 一对多: 角色是一, 用户是多, 外键写在多的一端
# - 多对多

class Role(db.Model):
    __tablename__ = "用户角色"
    # autoincrement=True id号递增
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(20))
    # 反向引用, Role表中有属性users, User类中有role这个属性
    users = db.relationship('User', backref='role')
    # 定义了 __repr()__ 方法, 返回一个具有可读性的字符串表示模型, 可在调试和测试时使用
    def __repr__(self):
        return "<Role %s>" % (self.name)

class User(db.Model):
    __tablename__ = "网站用户"
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(30), unique=True, index=True, nullable=False) 
    password = db.Column(db.String(20), nullable=False)
    email = db.Column(db.String(20), unique=True, index=True)
    # 设置默认值, 位当前用户的创建时间
    add_time = db.Column(db.DateTime, default=datetime.now())
    #### 重要的: 用户角色id不能随便设置, 需要从Role中查询(外键关联)
    # 外健写在多的一端
    role_id = db.Column(db.Integer, db.ForeignKey('用户角色.id'))
    def __repr__(self):
        return "<User %s>" % (self.username)
        
if __name__ == '__main__':
    db.drop_all()
    db.create_all()
    
    # ***********************1. 添加数据***********************
    # 1). 添加角色
    role1 = Role(name="普通用户")
    role2 = Role(name="会员")
    role3 = Role(name="管理员")

    db.session.add_all([role1, role2, role3])
    db.session.commit()
    # 2). 添加用户
    user1 = User(username="westos1", password="westos1",
                 email="westos1@qq.com", role_id=1)
    db.session.add(user1)
    db.session.commit()
    
	# ***********************2. 查看数据信息***********************
    print(User.query.all())
    print(Role.query.all())
    # 返回的是一个列表, 列表中有多个对象
    
    # ***********************批量添加100个普通用户, 50个VIP用户, 10个管理员***********************
    for item in range(100):
        user = User(
            username="fentiao%s" % (item),
            password="fentiao",
            email="fentiao%s" % (item),
            role_id=1
        )
        db.session.add(user)

    for item in range(50):
        user = User(
            username="vip%s" % (item),
            password="vip",
            email="vip%s" % (item),
            role_id=2
        )
        db.session.add(user)

    for item in range(10):
        user = User(
            username="admin%s" % (item),
            password="admin",
            email="admin%s" % (item),
            role_id=3
        )
        db.session.add(user)

    # ***********************将批量添加的用户提交到数据库中***********************
    db.session.commit()
    
    # ***********************获取所有的普通用户***********************
    common_users = User.query.filter_by(role_id='1').all()
    print(common_users)
    # 获取所有的vip用户
    vip_users = User.query.filter_by(role_id='2').all()
    print(vip_users)

    # ***********************获取所有的普通用户转化成的sql语句查看***********************
    print(User.query.filter_by(role_id='1'))
    print('*' * 10)
    print(User.query)
    
    # ***********************filter过滤器的使用(更偏向于SQL语句)***********************
    common_users = User.query.filter(User.role_id == 1).all()
    print(common_users)

    # ***********************limit过滤器, 只显示返回结果的前几条数据***********************
    common_users_limit = User.query.filter(User.role_id == 1).limit(5).all()
    print(common_users_limit)

    # ***********************offset过滤器: 偏移显示***********************
    common_users_offset = User.query.filter(User.role_id == 1).offset(2).limit(3).all()
    print(common_users_offset)
    
    # ***********************order_by排序过滤器, 默认是升序的, 如果要降序desc(属性名) ***********************
    common_users_order = User.query.order_by(User.role_id).all()
    print(common_users_order)
    # 降序
    common_users_desc_order = User.query.order_by(desc(User.role_id)).all()
    print(common_users_desc_order)
    
    # ***********************group_by, 分组统计***********************
    users_analysis = User.query.add_columns(func.count(User.role_id)).group_by(User.role_id).all()
    print(users_analysis)

    # ***********************get方法***********************
    print(User.query.get(1))
    # print(User.query.get_or_404(1000))

    # ***********************count***********************
    print(User.query.filter_by(role_id=1).count())
    print(User.query.filter_by(role_id=2).count())
    print(User.query.filter_by(role_id=3).count())

    # ***********************paginate分页的对象***********************
    # page=2: 要显示第2页的数据
    # per_page=5: 每页显示数据的条数
    
    usersPageObj = User.query.paginate(page=2, per_page=5)
    print("当前页面的记录数:", usersPageObj.items)
    print("分页查询的源sql语句:", usersPageObj.query)
    print("当前显示的页数:", usersPageObj.page)
    print("上一页的页数:", usersPageObj.prev_num)
    print("下一页的页数:", usersPageObj.next_num)
    print("是否包含上一页:", usersPageObj.has_prev)
    print("是否包含下一页:", usersPageObj.has_next)
    print("总页数:", usersPageObj.pages)
    print("每页记录的数量:", usersPageObj.per_page)
    print("记录总数:", usersPageObj.total)
    print("页码显示:", list(usersPageObj.iter_pages()))
    print("上一页的数据:", usersPageObj.prev().items)
    print("下一页的数据:", usersPageObj.next().items)

    # ***********************Role表反向引用***********************
    print("反向引用".center(100, '*'))
    admin_role = Role.query.filter_by(name="管理员").first()
    print(admin_role.id)
    print(admin_role.name)
    print(admin_role.users)

    # ***********************User表中***********************
    admin_user = User.query.filter_by(username='admin1').first()
    admin_user_id = admin_user.role_id
    print(Role.query.filter_by(id=admin_user_id).first().name)
    admin_user = User.query.filter_by(username='admin1').first()
    print(admin_user.role.name)

查询过滤器总结

在这里插入图片描述

sqlalchemy执行函数总结

在这里插入图片描述

分页对象拥有的属性

在这里插入图片描述

分页对象拥有的方法

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值