Rumah > Artikel > pembangunan bahagian belakang > Alat ajaib untuk pemula belajar Python dan bermain dengan SQL dalam masa lima minit!
Malah, saya menggunakan pymysql pada mulanya, tetapi mendapati penyelenggaraan menyusahkan dan terdapat risiko suntikan kod, jadi saya hanya menggunakan ORM rangka kerja secara langsung.
ORM ialah Object Relational Mapper, yang boleh difahami secara ringkas sebagai pemetaan antara jadual pangkalan data dan kelas Python Dengan mengendalikan kelas Python, anda boleh mengendalikan pangkalan data secara tidak langsung.
Rangka kerja ORM Python yang lebih terkenal ialah SQLAlchemy dan Peewee Saya tidak akan membuat perbandingan di sini, tetapi hanya menerangkan beberapa kegunaan peribadi SQLAlchemy saya harap ia dapat membantu semua rakan saya.
Ambil MySQL sebagai contoh Untuk membuat sambungan pangkalan data, anda hanya perlu menghantar rentetan DSN. Echo menunjukkan sama ada untuk mengeluarkan pernyataan SQL yang sepadan, yang berguna untuk penyahpepijatan.
Reka Bentuk Peribadifrom sqlalchemy import create_engine engine = create_engine('mysql+pymysql://$user:$password@$host:$port/$db?charset=utf8mb4', echo=True)
├── main.py ├── model │ ├── __init__.py │ ├── base_model.py │ ├── ddl.sql │ └── py_orm_model.py └── model_op ├── __init__.py └── py_orm_model_op.py
create table py_orm ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '唯一id', `name` varchar(255) NOT NULL DEFAULT '' COMMENT '名称', `attr` JSON NOT NULL COMMENT '属性', `ct` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `ut` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON update CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY(`id`) )ENGINE=InnoDB COMMENT '测试表';Pertama, kita dapat melihat bahawa PyOrmModel mewarisi kelas Base, yang merupakan kelas asas yang disediakan oleh sqlalchemy Ia akan melakukan beberapa semakan pada kelas Python yang kami isytiharkan dalam base_model.
# py_orm_model.py from .base_model import Base from sqlalchemy import Column, Integer, String, TIMESTAMP, text, JSON class PyOrmModel(Base): __tablename__ = 'py_orm' id = Column(Integer, autoincrement=True, primary_key=True, comment='唯一id') name = Column(String(255), nullable=False, default='', comment='名称') attr = Column(JSON, nullable=False, comment='属性') ct = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP'), comment='创建时间') ut = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP'), comment='更新时间')Kedua, setiap kelas Python mesti mengandungi atribut __tablename__, jika tidak jadual yang sepadan tidak boleh ditemui.
# base_model.py # 一般base_model做的都是一些初始化的工作 from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() engine = create_engine("mysql+pymysql://root:123456@127.0.0.1:33306/orm_test?charset=utf8mb4", echo=False)
Ketiga, terdapat dua cara untuk mencipta jadual data Yang pertama sudah tentu untuk menciptanya secara manual dalam MySQL Selagi tiada masalah dengan definisi kelas Python anda, ia boleh beroperasi secara normal adalah menggunakan penciptaan Bingkai ORM, seperti yang berikut:
Kesan penciptaan:# main.py # 注意这里的导入路径,Base创建表时会寻找继承它的子类,如果路径不对,则无法创建成功 from sqlachlemy_lab import Base, engine if __name__ == '__main__': Base.metadata.create_all(engine)Keempat, tentang atribut medan
... 2020-04-04 10:12:53,974 INFO sqlalchemy.engine.base.Engine CREATE TABLE py_orm ( id INTEGER NOT NULL AUTO_INCREMENT, name VARCHAR(255) NOT NULL DEFAULT '' COMMENT '名称', attr JSON NOT NULL COMMENT '属性', ct TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, ut TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (id) )1.primary_key dan autoincrement lebih mudah difahami , yang merupakan kunci utama dan atribut tambahan MySQL.
>>> from sqlalchemy.orm import sessionmaker >>> Session = sessionmaker(bind=engine) >>> session = Session() >>> orm = PyOrmModel(id=1, name='test', attr={}) >>> session.add(orm) >>> session.commit() >>> session.close()
1 Gunakan pengurus konteks untuk mengendalikan pemulangan dan penutupan sesi yang tidak normal.
2. Tambahkan dua kaedah pada PyOrmModel untuk penukaran antara model dan dict# base_model.py from contextlib import contextmanager from sqlalchemy.orm import sessionmaker, scoped_session def _get_session(): """获取session""" return scoped_session(sessionmaker(bind=engine, expire_on_commit=False))() # 在这里对session进行统一管理,包括获取,提交,回滚和关闭 @contextmanager def db_session(commit=True): session = _get_session() try: yield session if commit: session.commit() except Exception as e: session.rollback() raise e finally: if session: session.close()3 Enkapsulasi operasi pangkalan data adalah berbeza daripada artikel rujukan yang saya panggil secara langsung , supaya pemanggil tidak perlu memberi perhatian kepada lapisan model dan mengurangkan gandingan.
class PyOrmModel(Base): ... @staticmethod def fields(): return ['id', 'name', 'attr'] @staticmethod def to_json(model): fields = PyOrmModel.fields() json_data = {} for field in fields: json_data[field] = model.__getattribute__(field) return json_data @staticmethod def from_json(data: dict): fields = PyOrmModel.fields() model = PyOrmModel() for field in fields: if field in data: model.__setattr__(field, data[field]) return model4. Pemanggil
# py_orm_model_op.py from sqlachlemy_lab.model import db_session from sqlachlemy_lab.model import PyOrmModel class PyOrmModelOp: def __init__(self): pass @staticmethod def save_data(data: dict): with db_session() as session: model = PyOrmModel.from_json(data) session.add(model) # 查询操作,不需要commit @staticmethod def query_data(pid: int): data_list = [] with db_session(commit=False) as session: data = session.query(PyOrmModel).filter(PyOrmModel.id == pid) for d in data: data_list.append(PyOrmModel.to_json(d)) return data_listUntuk kod lengkap, sila lihat:
# main.py from sqlachlemy_lab.model_op import PyOrmModelOp if __name__ == '__main__': PyOrmModelOp.save_data({'id': 1, 'name': 'test', 'attr': {}})
https://github.com/yangancode/ python_lab/ tree/master/sqlachlemy_labAtas ialah kandungan terperinci Alat ajaib untuk pemula belajar Python dan bermain dengan SQL dalam masa lima minit!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!