flask 相关的的SQLAlchemy模板操作

1.manager.py


from flask import Flask
from flask_script import Manager

from app.models import db
from app.views import blue

app = Flask(__name__)

app.register_blueprint(blueprint=blue)

# 配置数据库连接信息
# dialect+driver://username:password@host:port/database
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:123456@127.0.0.1:3306/flask9'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db.init_app(app)

manage = Manager(app)

if __name__ == '__main__':
    manage.run()

2.app.models.py (app包下面的models.py文件)


from flask_sqlalchemy import SQLAlchemy

# 生成数据库访问对象db
db = SQLAlchemy()


class Student(db.Model):
    # 定义id主键,自增字段
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    # 定义不能为空,且唯一的姓名字段
    s_name = db.Column(db.String(10), unique=True, nullable=False)
    # 定义整型,默认为20的年龄字段
    age = db.Column(db.Integer, default=20)

    __tablename__ = 'stu'

    def save(self):
        # 保存与修改
        db.session.add(self)
        db.session.commit()

    def delete(self):
        db.session.delete(self)
        db.session.commit()

3.app.views.py(app下的py文件)


from flask import Blueprint
from sqlalchemy import and_, not_, or_

from app.models import db, Student

blue = Blueprint('app', __name__)


@blue.route('/')
def hello():
    return 'hello world'


@blue.route('/create_db/')
def create_db():
    # 迁移模型
    # 第一次迁移模型时才有用
    db.create_all()
    # 删除表
    # db.drop_all()
    return '创建表成功'


@blue.route('/add_stu/')
def add_stu():
    # 新增学生数据
    stu = Student()
    stu.s_name = '小蕊'
    stu.age = 20
    # 准备向数据库flask9中的student表中插入数据
    db.session.add(stu)
    # 提交操作
    db.session.commit()
    return '创建数据成功'


@blue.route('/add_stus/')
def add_stus():
    # 批量插入内容
    stu_list = []
    for i in range(10):
        stu = Student()
        stu.s_name = '小李' + str(i)
        stu.age = int(i)
        stu_list.append(stu)
        # db.session.add(stu)
    db.session.add_all(stu_list)
    db.session.commit()
    return '批量插入数据成功'


@blue.route('/sel_stu/')
def sel_stu():
    # select * from stu where s_name='小张0'
    # stu = Student.query.filter_by(s_name='小张0').all()[0]
    stu = Student.query.filter_by(s_name='小张0').first()
    print(stu.s_name)
    print(stu.age)
    return '查询数据成功'


@blue.route('/del_stu/')
def del_stu():
    # 删除年龄等于0的信息
    stus = Student.query.filter_by(age=0).all()
    for stu in stus:
        db.session.delete(stu)
    db.session.commit()
    return '删除数据成功'


@blue.route('/update_stu/')
def update_stu():
    # 修改,先获取需要修改的对象
    stu = Student.query.filter_by(s_name='小张1').first()
    stu.age = 10
    # db.session.add(对象)  可以不用写
    # db.session.add(stu)
    # db.session.commit()
    stu.save()
    return '修改数据成功'


@blue.route('/sel_stus/')
def sel_stus():

    stu = Student.query.filter_by(s_name = '小张1').first()
    stu = Student.query.filter(Student.s_name == '小张1').first()
    print(stu)

    # 查询所有学生信息
    # all()结果为列表,列表中的元素为查询的学生对象
    stus = Student.query.all()
    print(stus)

    # 查询id=1的学生信息
    stu = Student.query.filter(Student.id == 1).first()
    print(stu)
    # get(): 查询主键所在行的信息,主键为id。查询不到数据,返回None
    stu = Student.query.get(1)
    print(stu)

    # 排序 order_by()
    # 升序: order_by(Student.id)
    # 降序: order_by(-Student.id)
    stus = Student.query.order_by(-Student.id).all()
    print(stus)

    # offset  limit   limit 1,4
    page = 2
    stus = Student.query.limit(3).all()
    stus = Student.query.all()
    # stus[0:3]  stus[3:6]
    stus[(page-1)*3 : page*3]

    stus = Student.query.offset((page-1)*3).limit(3).all()
    print(stus)

    # 模糊查询 like % _
    stus = Student.query.filter(Student.s_name.contains('小张')).all()
    print(stus)
    stus = Student.query.filter(Student.s_name.like('%小张%')).all()

    stus = Student.query.filter(Student.s_name.like('_张')).all()
    stus = Student.query.filter(Student.s_name.like('张_')).all()
    # startswith: 以什么开头
    # endswith: 以什么结束
    stus = Student.query.filter(Student.s_name.startswith('张')).all()
    stus = Student.query.filter(Student.s_name.endswith('张')).all()

    # 大于 gt  小于lt
    # 大于等于ge   小于等于le
    stus = Student.query.filter(Student.age.__ge__(10)).all()
    stus = Student.query.filter(Student.age >= 10).all()
    print(stus)

    # where id not in [1,2,3,4,5,6,7]
    stus = Student.query.filter(Student.id.in_([1,2,3,4,5,6,7])).all()
    stus = Student.query.filter(Student.id.notin_([1,2,3,4,5,6,7])).all()
    print(stus)

    # 多条件查询
    stus = Student.query.filter(Student.age == 2).\
        filter(Student.s_name.like('小%')).all()

    stus = Student.query.filter(Student.age == 2,
                                Student.s_name.like('小%')).all()

    # and 或者or
    stus = Student.query.filter(Student.age == 2 and Student.s_name.like('小%')).all()
    # and_, or_, not_
    stus = Student.query.filter(and_(Student.age == 2,
                                Student.s_name.like('小%'))).all()
    stus = Student.query.filter(or_(Student.age == 2,
                                     Student.s_name.like('小%'))).all()
    stus = Student.query.filter(not_(Student.age == 2)).all()

    print(stus)

    return '查询学生信息'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,084评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,623评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,450评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,322评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,370评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,274评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,126评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,980评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,414评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,599评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,773评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,470评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,080评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,713评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,852评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,865评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,689评论 2 354

推荐阅读更多精彩内容