sangreal-db
基于sqlalchemy的python数据库orm包,加入对交互式编程的支持,更简易的API。
注意
自动补全功能在ipython>7.1.1的版本下会出现卡顿现象,如果需要,请回滚至该本版或以下。
安装
pip install sangreal-db
使用方法
建表
from sangreal_db import DataBase
from sqlalchemy import create_engine
engine = create_engine('mysql://....')
engine = 'mysql://....'
db = DataBase(engine, schema=None)
from sqlalchemy import Column, Integer, String
class User(db.Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
name = Column(String(20))
fullname = Column(String(20))
password = Column(String(20))
def __repr__(self):
return "<User(name='%s', fullname='%s', password='%s')>" % (
self.name, self.fullname, self.password)
db.create_all()
查
更多api用法可参考python对Mysql操作和使用ORM框架(SQLAlchemy)
table = db.TABLE_NAME
table.COLUMN
db.query(table).filter(table.COLUMN==....).all()
db.query(table).filter(...).to_df()
增/改 (适用于逐条增改)
t_obj_add = table(c1=xxx, c2=xxx, c3=xxx)
db.update(t_obj_add)
db.commit()
t_obj_update = db.query(table).filter(...).all()
for t in t_obj_update:
t.c1 = xxx
db.update(t_obj_update)
db.commit()
t_change = [t_obj_add] + t_obj_update
db.update(t_change)
db.commit()
db.query(table).filter(...).update({table.c1: "hello"}, synchronize_session=False)
db.commit()
批量插入
import pandas as pd
df = pd.DataFrame(...)
db.insert(table, df, ignore=True)
db.commit()
删
t_obj_delete = db.query(table).filter(...).first()
db.delete(t_obj_delete)
db.commit()
db.query(table).filter(...).delete()
db.commit()
ipython or jupyter-notebook
实例化Database类后,sangreal-db会自动为该实例添加以表名命名的属性,这点在交互式编程中十分方便。
需要注意的是,该属性为懒加载,并不会一次性将database下的所有表映射成Table类,只有在单独调用时才会映射对应的表,解决了性能问题。

