python核心编程---读书笔记:第21章 数据库编程

 

第21章数据库编程

21.1 持久存储

现有ORM,shelve

数据库:MySQL基于服务器的关系数据uguanli系统

 

21.2 Python数据库应用程序

程序员接口(DB-API):定义对象和数据库存取方式

游标对象:允许用户执行数据库命令和得到查询结果

 

类型对象构造器

Date(yr,mo,dy) : 日期值对象

Time(hr , min, sec):时间值对象

STRING:字符串对象

NUMBER:数字列的对象

 

21.2.6 数据库和Python: 接口程序

 

21.3 对象-关系管理器(ORMs)

21.3.1 考虑对象,而不是SQL

将SQL层功能抽象为Python对象

数据库的表被转换为Python类,具有列属性和操作数据库的方法

 

Python的ORM模块:SQLAlchemy和SQLObject

web框架也有子集的ORM组建,如Django的数据库API

 

 

21.3.3 sqlalchemy举例

# *-* coding: utf-8*-*

'''
ORM : Object-Relation Mapping,对象关系映射,把关系数据库的表
结构映射到对象上。
'''
from sqlalchemy import Column, String , create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship
from sqlalchemy.schema import ForeignKey
from sqlalchemy.orm import mapper
from sqlalchemy importMetaData , Table , Integer

import pymysql

#创建类的基类,声明_基类会创建一个BaseModel类,这个类的子类可以自动与表关联
Base =declarative_base()

metadata = MetaData()
user = Table('user' , metadata ,
             Column('id' , String(50) , primary_key=True),
             Column('name' , String(50))
             )

#使用mapper关联表和对象,对象的父类不能是Base必须是object,而且必须采用def __init__ 初始化
class User(object):
    def __init__(self , id , name):
        self.id =id
        self.name= name

#将类User和user关联起来,但是必须先在mysql中创建表
mapper(User , user)

def addUser():


    #初始化数据库连接,创建引擎(数据库类型+数据库驱动名称://用户名:口令@机器地址:端口号/数据库名)
    #engine =create_engine("mysql+mysqlconnector://root:123456@localhost:3306/test")
    #注意这里安装的是pymsql,那么数据库驱动名称就要修改为pymysql
    engine = create_engine('mysql+pymysql://root:123456@localhost:3306/test')
    #创建数据库会话,会话创造器会绑定数据库引擎
    DBSession = sessionmaker(bind=engine)

    #创建session对象,进行真正的连接
    session = DBSession()

    #创建新User对象
    new_user = User(id='7' , name='Dong')
    #将对象添加到会话中
    session.add(new_user)
    session.commit()


    #查询
    user = session.query(User).filter(User.id=='5').one()
    print('type' , type(user))
    print('name' , user.name)
    user.name = 'dongfei'
    session.commit()
    session.close()

class Person(Base):
    #表的名字是静态成员变量
    __tablename__ = 'person'

    #表的结构
    id = Column(String(20) , primary_key=True)
    name = Column(String(20))

def addPerson():
    engine = create_engine('mysql+pymysql://root:123456@localhost:3306/test')
    #创建数据库会话,会话创造器会绑定数据库引擎
    DBSession = sessionmaker(bind=engine)

    #创建session对象,进行真正的连接
    session = DBSession()

    #创建新User对象
    new_user = Person(id='7' , name='Dong')
    #将对象添加到会话中
    session.add(new_user)
    session.commit()

def main():
    addUser()
    addPerson()



if __name__ == "__main__":
    main()


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值