ORM (Object-Relational Mapping) ialah teknologi pengaturcaraan yang memetakan data jadual dalam pangkalan data hubungan kepada objek dalam bahasa pengaturcaraan, membenarkan pembangun program mengendalikan pangkalan data dalam cara berorientasikan objek. Flask-SQLAlchemy ialah rangka kerja ORM yang berkuasa yang boleh memudahkan operasi program Python pada pangkalan data hubungan.
Artikel ini akan memperkenalkan penggunaan rangka kerja Flask-SQLAlchemy secara terperinci melalui contoh.
Sebelum mempelajari Flask-SQLAlchemy, kita perlu memasang modul Flask dan SQLAlchemy. Anda boleh memasangnya menggunakan arahan pip dalam persekitaran Python.
pip install Flask
pip install SQLAlchemy
Konfigurasikan pangkalan data MySQL sebagai storan berterusan projek, sebelum mencipta Flask -SQLAlchemy objek, hanya lulus parameter berikut:
dari Flask import Flask
dari flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:password@localhost:3306/test'
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db> SQL🎜>db = SQL🎜>
Panggil app.config untuk menetapkan parameter konfigurasi contoh aplikasi Flask Parameter SQLALCHEMY_DATABASE_URI digunakan untuk menentukan jenis pangkalan data yang disambungkan, nama pengguna, kata laluan, alamat IP, nombor port, nama pangkalan data dan maklumat lain.daripada flask_sqlalchemy import SQLAlchemy
# 定义表名 __tablename__ = 'student' # 定义表结构,其中id为主键,自增长 id = db.Column(db.Integer, primary_key=True, autoincrement=True) name = db.Column(db.String(20), nullable=False) gender = db.Column(db.String(2), nullable=False) birthday = db.Column(db.Date, default=datetime.now()) address = db.Column(db.String(200), nullable=False) # 类对象序列化成字典 def to_dict(self): return {c.name: getattr(self, c.name, None) for c in self.__table__.columns}
def add_student():
student = Student() student.name = request.form.get('name') student.gender = request.form.get('gender') student.birthday = datetime.strptime(request.form.get('birthday'), '%Y-%m-%d').date() student.address = request.form.get('address') db.session.add(student) db.session.commit() return jsonify({'code': 200, 'msg': 'add student success.'})
def delete_student(id ):
student = Student.query.get(id) if student: db.session.delete(student) db.session.commit() return jsonify({'code': 200, 'msg': 'delete student success.'}) else: return jsonify({'code': 404, 'msg': 'student not found.'})
def update_student(id ):
student = Student.query.get(id) if student: student.name = request.form.get('name') student.gender = request.form.get('gender') student.birthday = datetime.strptime(request.form.get('birthday'), '%Y-%m-%d').date() student.address = request.form.get('address') db.session.commit() return jsonify({'code': 200, 'msg': 'update student success.'}) else: return jsonify({'code': 404, 'msg': 'student not found.'})
def search_student():
students = Student.query.all() if students: return jsonify({'code': 200, 'msg': 'search student success.', 'data': [student.to_dict() for student in students]}) else: return jsonify({'code': 404, 'msg': 'student not found.'})
Atas ialah kandungan terperinci Rangka kerja ORM Flask-SQLAlchemy dalam Python dalam amalan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!