FLask SQLAlchemy

FLask SQLAlchemy 实际上是 SQLAlchemy 在 Flask 框架中的封装。因此,FLask SQLAlchemy 支持 SQLAlchemy 中的所有语法,以下是 SQLAlchemy 中常用的一些语法(不限于 Flask SQLAlchemy,适用于所有使用 SQLAlchemy 的项目):

创建表格
from sqlalchemy import Column, Integer, String, DateTime
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class User(Base):
tablename = ‘users’

id = Column(Integer, primary_key=True)
name = Column(String(50), nullable=False)
email = Column(String(120), nullable=False, unique=True)
created_at = Column(DateTime, default=datetime.datetime.utcnow)

连接数据库
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

engine = create_engine(‘postgresql://user:password@localhost/mydatabase’)
Session = sessionmaker(bind=engine)
session = Session()
创建关联关系
from sqlalchemy import ForeignKey
from sqlalchemy.orm import relationship

class Address(Base):
tablename = ‘addresses’

id = Column(Integer, primary_key=True)
street = Column(String(120))
city = Column(String(50))
state = Column(String(50))
zipcode = Column(String(10))
user_id = Column(Integer, ForeignKey('users.id'))

user = relationship("User", back_populates="addresses")

添加数据
user = User(name=‘John Doe’, email=‘john.doe@example.com’)
session.add(user)
session.commit()

address = Address(street=‘123 Main St’, city=‘Springfield’, state=‘IL’, zipcode=‘12345’, user=user)
session.add(address)
session.commit()
查询数据

查询所有数据

users = session.query(User).all()

根据条件查询单个数据

user = session.query(User).filter_by(id=1).first()

连接查询,获取用户及其关联的地址信息

user_with_addresses = session.query(User).join(User.addresses).filter_by(id=1).first()
更新数据
user = session.query(User).filter_by(id=1).first()
user.name = ‘Jane Doe’
session.commit()
删除数据
user = session.query(User).filter_by(id=1).first()
session.delete(user)
session.commit()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现一个带有注册登录功能的管理系统,可以使用 Flask 框架和 SQLAlchemy 库来实现。以下是一个简单的示例: 1. 安装 FlaskSQLAlchemy ```python pip install Flask SQLAlchemy ``` 2. 创建 Flask 应用 ```python from flask import Flask app = Flask(__name__) ``` 3. 配置数据库 ```python from flask_sqlalchemy import SQLAlchemy app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:password@localhost/db_name' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db = SQLAlchemy(app) ``` 4. 定义用户模型 ```python class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(50), unique=True, nullable=False) password = db.Column(db.String(100), nullable=False) def __repr__(self): return f'<User {self.username}>' ``` 5. 创建数据库表 ```python db.create_all() ``` 6. 创建注册和登录路由 ```python from flask import render_template, request, redirect, url_for, flash from werkzeug.security import generate_password_hash, check_password_hash @app.route('/register', methods=['GET', 'POST']) def register(): if request.method == 'POST': username = request.form['username'] password = request.form['password'] user = User.query.filter_by(username=username).first() if user: flash('Username already exists.') return redirect(url_for('register')) new_user = User(username=username, password=generate_password_hash(password, method='sha256')) db.session.add(new_user) db.session.commit() flash('Account created.') return redirect(url_for('login')) return render_template('register.html') @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': username = request.form['username'] password = request.form['password'] remember = True if request.form.get('remember') else False user = User.query.filter_by(username=username).first() if not user or not check_password_hash(user.password, password): flash('Incorrect username or password.') return redirect(url_for('login')) session['user_id'] = user.id session['username'] = user.username flash('Logged in successfully.') return redirect(url_for('home')) return render_template('login.html') ``` 7. 创建需要登录才能访问的路由 ```python from flask_login import login_required @app.route('/home') @login_required def home(): return render_template('home.html') ``` 8. 创建注销路由 ```python from flask_login import logout_user @app.route('/logout') @login_required def logout(): logout_user() flash('Logged out successfully.') return redirect(url_for('login')) ``` 9. 运行应用程序 ```python if __name__ == '__main__': app.run(debug=True) ``` 以上是一个简单的示例,可以根据需要进行修改和扩展。同时,为了实现注册登录功能,我们还需要使用 Flask-Login 扩展来管理用户会话。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值