# hm_03_数据查询.py
from flask import Flask from flask import request, Response,render_template from flask_sqlalchemy import SQLAlchemy import os
app = Flask(__name__)
# 相关配置 app.config["SQLALCHEMY_DATABASE_URI"] = "mysql://root:123456@127.0.0.1:3306/test" app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False app.config["SQLALCHEMY_ECHO"] = False db = SQLAlchemy(app)
# 自定义类 继承db.Model ?对应 表 class User(db.Model): ? ? __tablename__ = "users" ?# 表名 默认使用类名的小写 ? ? # 定义类属性 记录字段 ? ? id = db.Column(db.Integer, primary_key=True) ? ? name = db.Column(db.String(64)) ? ? email = db.Column(db.String(64)) ? ? age = db.Column(db.Integer)
? ? def __repr__(self): ?# 自定义 交互模式 & print() 的对象打印 ? ? ? ? return "(%s, %s, %s, %s)" % (self.id, self.name, self.email, self.age)
@app.route('/') def index(): ? ? ?? ?? ?# 1:查询所有的用户数据: ? ? users = User.query.all() ?? ? ? return "{}!".format(users) ? ?# return 'hello world'
@app.route('/fenye') def fenye(): ? ? page = int(request.args.get('page',1)) ? ? per_page = int(request.args.get('per_page',25)) ? ? paginator = User.query.paginate(page,per_page,error_out=False) ? ? return render_template('fenye.html',data=paginator) if __name__ == '__main__': ? ?? ?
? ?#print(list1) ? ? # 删除所有表 ? ?# db.drop_all() ? ? # 创建所有表 ? ?# db.create_all() ? ? # 添加测试数据 ? ? user1 = User(name='wang', email='wang@163.com', age=20) ? ? user2 = User(name='zhang', email='zhang@189.com', age=33) ? ? user3 = User(name='chen', email='chen@126.com', age=23) ? ? user4 = User(name='zhou', email='zhou@163.com', age=29) ? ? user5 = User(name='tang', email='tang@itheima.com', age=25) ? ? user6 = User(name='wu', email='wu@gmail.com', age=25) ? ? user7 = User(name='qian', email='qian@gmail.com', age=23) ? ? user8 = User(name='liu', email='liu@itheima.com', age=30) ? ? user9 = User(name='li', email='li@163.com', age=28) ? ? user10 = User(name='sun', email='sun@163.com', age=26)
? ? # 一次添加多条数据 ? ? db.session.add_all([user1, user2, user3, user4, user5, user6, user7, user8, user9, user10]) ? ? db.session.commit() ? ? app.run(debug=True) ?
|