flask数据库操作命令

数据库增加,删除,修改操作:
增加:
user = User(name=’laowang’)
db.session.add(user)
db.session.commit()

修改:
user.name = ‘xiaohua’
db.session.commit()

删除:
db.session.delete(user)
db.session.commit()

查询所有用户数据
User.query.all()

查询有多少个用户
User.query.count()

查询第1个用户
User.query.all()[0]

查询id为4的用户[3种方式]
User.query.get(4)
User.query.filter_by(id = 4).first()
User.query.filter(User.id == 4).first()

查询名字结尾字符为g的所有数据[开始/包含]
User.query.filter(User.name.endwith(‘g’)).all()
User.query.filter(User.name.startswith(‘g’)).all()
User.query.filter(User.name.contains(‘g’)).all()

查询名字不等于wang的所有数据[2种方式]
查询名字和邮箱都以 li 开头的所有数据[2种方式]
User.query.filter(User.name.startswith(‘li’),User.email.startswith(‘li’)).all()
User.query.filter(and_(User.name.startswith(‘li’),User.email.startswith(‘li’))).all()

查询password是 123456 或者 email.com 结尾的所有数据
User.query.filter(or_(User.password == ‘123456’,User.email.endswith(‘.com’))).all()

查询id为 [1, 3, 5, 7, 9] 的用户列表
User.query.filter(User.id.in_([1,3,5,7,9])).all()

查询name为liu的角色数据
user = User.query.filter(User.name == ‘liu’).first()
role = Role.query.filter(Role.id == user.role_id).first()

查询所有用户数据,并以邮箱排序
User.query.order_by(User.email).all()
User.query.order_by(User.email.desc()).all()

每页3个,查询第2页的数据
paginate = User.query.paginate(page, per_page,Error_out)
paginate = User.query.paginate(2,3,False)
page: 哪一个页
per_page: 每页多少条数据
Error_out: False 查不到不报错
pages: 共有多少页
items: 当前页数的所有对象

你可能感兴趣的:(flask数据库操作命令)