使用pycharm连接数据库---Sqlalchemy

初识sqlalchemy

from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,String,INTEGER
#1.创建引擎
eng = create_engine("mysql+pymysql://root:admin@localhost/homework?charset=utf8")
print(eng)
#2.创建基类
Base = declarative_base()
#3.创建类(模型)
class Student(Base):
    __tablename__="student1"#指定表格名称
    id = Column(INTEGER,primary_key=True,autoincrement=True)
    name = Column(String(32),nullable=False)#非空约束
    email = Column(String(32),unique=True)#唯一约束

#4.创建表格
Base.metadata.create_all(eng)
#5删除表格
Base.metadata.drop_all(eng)

创建出来的student1表
使用pycharm连接数据库---Sqlalchemy_第1张图片
使用pycharm连接数据库---Sqlalchemy_第2张图片
使用Sqlalchemy四部曲:
1、使用create_engine()#连接数据库
2、Base = declarative_base()# 生成orm基类,用于创建classes
3、Base.metadata.create_all(engine) #关联engine使用metadata创建数据库表
4、使用 session = Session(engine) #创建一个会话,便于后面对数据库进行实际操作

from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,String,INTEGER
from sqlalchemy.orm import sessionmaker
#1.创建引擎
eng = create_engine("mysql+pymysql://root:admin@localhost/homework?charset=utf8")
#2.创建基类
Base = declarative_base()
#3.创建类(模型)
class Student(Base):
    __tablename__ = "student2"
    id = Column(INTEGER,primary_key=True,autoincrement=True)
    name = Column(String(32), nullable=False)  # 非空约束
    email = Column(String(32), unique=True)  # 唯一约束
#4.创建表格
Base.metadata.create_all(eng)
#5.创建session
Session = sessionmaker(bind=eng)
session = Session()#创建session对象,相当于pymysql中的conn
#增加记录
# student = Student(name='刘备',email='[email protected]')#创建student的对象
# session.add(student)#添加记录

# #批量增加
# session.add_all(
#     [
# Student(name='张飞',email='[email protected]'),
# Student(name='悟空',email='[email protected]'),
# Student(name='宫本',email='[email protected]'),
# Student(name='赵云',email='[email protected]'),
#     ]
# )


#查询操作
#first方法查询出第一条记录
# ret = session.query(Student).first()
# print(ret.id,ret.name,ret.email)
# #get方法查询指定记录
# student = session.query(Student).get(ident=2)#使用唯一标识ident不写也行查询第几条记录
# print(student.id,student.name,student.email)
#
# student = session.query(Student).filter(Student.id>2)#filter过滤相当于条件
# for stu in student:#这里的student是个对象,所以需要把他遍历出来显示查询出来的数据
#     print(stu.id,stu.name,stu.email)




# #删除操作
# # student = session.query(Student).filter(Student.id<2).delete()
# # #方式一此方法可删除多个主要是因为filter,他是条件吗满足他的都可以被删除
# student1 = session.query(Student).get(2)
# session.delete(student1)#方式二




# #修改操作
#单条修改
# student3 =session.query(Student).first()
# student3.name='百度'
# student3.email='www.baidu.com'
#指定条件修改
student4 =session.query(Student).filter(Student.id ==3).update({Student.name:'王炸',Student.email:'[email protected]'})
session.commit()#提交事务
session.close()

使用pycharm连接数据库---Sqlalchemy_第3张图片
使用pycharm连接数据库---Sqlalchemy_第4张图片
在这里插入图片描述
使用pycharm连接数据库---Sqlalchemy_第5张图片
使用pycharm连接数据库---Sqlalchemy_第6张图片
使用pycharm连接数据库---Sqlalchemy_第7张图片
使用pycharm连接数据库---Sqlalchemy_第8张图片
使用pycharm连接数据库---Sqlalchemy_第9张图片

你可能感兴趣的:(使用pycharm连接数据库---Sqlalchemy)