创建表和添加数据import sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy import Column, Integer, Stringfrom sqlalchemy.orm import sessionmakerengine = create_engine("mysql+pymysql://root:lizhaoqwe@10.20.252.223/test_db", echo=True)#echo=True可以查看详细信息Base = declarative_base()#创建表class User(Base): __tablename__ = 'user'#表名 id = Column(Integer, primary_key=True) name = Column(String(32)) password = Column(String(64))
def __repr__(self):#显示ORM查询执行后的结果(不加这个方法返回的是内存地址) return '%s:%s' % (self.name, self.password)
Base.metadata.create_all(engine) #创建表结构#创建连接Session_class = sessionmaker(bind=engine) #创建与数据库的会话session class,注意,这里返回的是一个类,不是一个实例session = Session_class()#生成session实例 #可以先理解成curson游标#查询
# data = session.query(User).filter(User.id < 2).all()#是一个列表data = session.query(User).filter(User.id > 2).filter(User.id < 5)#查询出来后直接赋值修改数据
data.name = 'username'data.password = 'password'session.commit()
print(data)
#插入数据
user_obj1 = User(name='lizhao', password='lizhaoqwe123')#生成要创建的数据对象user_ibj2 = User(name='test', password='testqwe123')session.add(user_obj1)session.add(user_ibj2)session.commit()#必须commit之后才会添加数据
ORM操作mysql
点赞
收藏