`
剑事
  • 浏览: 63136 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

SQLAlchemy 0.5 中文文档 ---- 对象关系(1)

阅读更多

在这篇教程里我们将封装一个基本的SQLAlchemy对象关系映射脚本,通过数据库表现来存储和检索python对象

 

版本检查

 

检查当前安装的sqlalchemy是否为0.5版本

 

>>> import sqlalchemy
>>> sqlalchemy.__version__ 
0.5.0

 

建立链接

 

这里我们使用sqlite数据库,使用create_engine()连接

 

 

>>> from sqlalchemy import create_engine
>>> engine = create_engine('sqlite:///:memory:', echo=True)

 

echo 表示是否打开sqlalchemy的日志输出,使用的是python标准的日志组件,echo开启后,我们将会看到所有生成的sql.

 

定义和创建表

 

下一步我们把表告诉给sqlalchemy,我们先作一个users表来存储末端用户(假设是网站的用户),我们在 MetaData范围内

定义表,使用类似SQL脚本的结构.。

 

>>> from sqlalchemy import Table, Column, Integer, String, MetaData, ForeignKey
>>> metadata = MetaData()
>>> users_table = Table('users', metadata,
...     Column('id', Integer, primary_key=True),
...     Column('name', String),
...     Column('fullname', String),
...     Column('password', String)
... )

 下一步我们可以通过调用 create_all() 来发布创建表的声明,

 

>>> metadata.create_all(engine) 
PRAGMA table_info("users")
 {} 
CREATE TABLE users (
 id INTEGER NOT NULL, 
name VARCHAR,
 fullname VARCHAR, 
password VARCHAR, 
PRIMARY KEY (id) ) 
{}
 COMMIT

 你会发现 VARCHAR 列没有指定长度,SQLite下是可以的,不过大多数其它数据库是不允许的,如果你想指定长度可以这样

 

Column('name', String(50))

 

这个也适合用在其它可变长度的字段类型。

 

用python对象定义表映射

 

我们来定义一个基本的用户类

>>> class User(object):
...     def __init__(self, name, fullname, password):
...         self.name = name
...         self.fullname = fullname
...         self.password = password
...
...     def __repr__(self):
...        return "<User('%s','%s', '%s')>" % (self.name, self.fullname, self.password)

 

设置映射

 

我们把users_table User 绑定结合,使用sqlalchemy的 mapper创建映射

 

>>> from sqlalchemy.orm import mapper
>>> mapper(User, users_table) 
<Mapper at 0x...; User>

 

mapper()函数创建了新的对象和和存储之间的映射, 现在我们创建和检查用户对象

>>> ed_user = User('ed', 'Ed Jones', 'edspassword')
>>> ed_user.name
'ed'
>>> ed_user.password
'edspassword'
>>> str(ed_user.id)
'None'

 

 

 

 

id属性没有定义在 __init__() 中,他存在于 users_table

 

一次性创建表,对象和映射  

 

>>> from sqlalchemy.ext.declarative import declarative_base

>>> Base = declarative_base()
>>> class User(Base):
...     __tablename__ = 'users'
...
...     id = Column(Integer, primary_key=True)
...     name = Column(String)
...     fullname = Column(String)
...     password = Column(String)
...
...     def __init__(self, name, fullname, password):
...         self.name = name
...         self.fullname = fullname
...         self.password = password
...
...     def __repr__(self):
...        return "<User('%s','%s', '%s')>" % (self.name, self.fullname, self.password)

  

 上面 declarative_base() 功能实现了一个新的类Base,User 继承 Base

 

创建Session

 

orm操作数据库用的是session

 

 

 

>>> from sqlalchemy.orm import sessionmaker
>>> Session = sessionmaker(bind=engine)

 如果没有engine 可以如下定义

 

 

>>> Session = sessionmaker()

 实例化session

>>> session = Session()

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Python库 | SQLAlchemy-1.4.0b1-cp39-cp39-macosx_10_14_x86_64.whl

    资源分类:Python库 所属语言:Python 资源全名:SQLAlchemy-1.4.0b1-cp39-cp39-macosx_10_14_x86_64.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    PyPI 官网下载 | sqlalchemy_cockroachdb-1.3.0-py3-none-any.whl

    SQLAlchemy是Python中广泛使用的ORM(对象关系映射)库,它允许开发者用Python对象来操作数据库,使得数据库操作更加简洁和面向对象。SQLAlchemy提供了一个强大的SQL构建器,支持动态SQL执行,并且可以与多种数据库...

    sqlalchemy工具书--英文原版

    SQLAlchemy 是 Python 编程语言中最流行的 ORM(对象关系映射)工具之一。它被设计为用于将 Python 代码映射到数据库结构的工具包,从而允许开发人员用面向对象的方式来操作数据库。 标题所指的“sqlalchemy工具书-...

    SQLAlchemy技术文档(中文版)

    ### SQLAlchemy技术文档(中文版)知识点总结 #### 1. 版本检查 - **功能说明**:在使用SQLAlchemy之前,确保安装的版本符合项目需求是非常重要的。可以通过导入SQLAlchemy包并调用`__version__`属性来检查当前安装的...

    SQLAlchemy-1.4.22-cp38-cp38-win_amd64

    SQLAlchemy-1.4.22-cp38-cp38-win_amd64

    Python库 | SQLAlchemy-1.3.20-cp38-cp38-manylinux1_x86_64.whl

    **SQLAlchemy**是Python编程语言中的一个强大的对象关系映射(ORM)库,它提供了全面的数据库工具,允许开发者以Python对象的方式操作数据库。在这个场景中,我们关注的是`SQLAlchemy-1.3.20-cp38-cp38-manylinux1_x86...

    Python库 | SQLAlchemy-1.4.12-cp39-cp39-win_amd64.whl

    python库。资源全名:SQLAlchemy-1.4.12-cp39-cp39-win_amd64.whl

    PyPI 官网下载 | SQLAlchemy-JSONAPI-4.0.4.tar.gz

    1. **JSONAPI 格式支持**:此库提供了将 SQLAlchemy 模型映射到 JSONAPI 标准格式的能力。这包括了资源对象、关系、包含(inclusions)以及分页等。 2. **序列化与反序列化**:SQLAlchemy-JSONAPI 提供了将 ...

    Python库 | aiohttp_sqlalchemy-0.1b1-py3-none-any.whl

    资源分类:Python库 所属语言:Python 使用前提:需要解压 资源全名:aiohttp_sqlalchemy-0.1b1-py3-none-any.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    Python库 | alicorn_sqlalchemy-0.0.1a9-py3-none-any.whl

    Python库`alicorn_sqlalchemy`是一个专门为Python编程语言设计的扩展模块,用于增强对SQLAlchemy数据库 ORM(对象关系映射)框架的支持。SQLAlchemy是Python中广泛使用的数据库接口,它提供了一个强大的ORM系统,...

    SQLAlchemy-1.4.22-cp37-cp37m-win_amd64

    SQLAlchemy-1.4.22-cp37-cp37m-win_amd64

    SQLAlchemy-1.2.17-cp34-cp34m-win_amd64

    SQLAlchemy-1.2.17-cp34-cp34m-win_amd64

    sqlalchemy documentation sqlalchemy 文档

    根据提供的文档信息,我们可以归纳出一系列关于SQLAlchemy的知识点,主要涵盖了概述与安装、对象关系映射教程、SQL表达式语言教程以及映射器配置等内容。以下是对这些知识点的详细阐述: ### 概述与安装 #### 1.1 ...

    Python库 | sqlalchemy2_stubs-0.0.2a17-py3-none-any.whl

    SQLAlchemy是Python中广泛使用的对象关系映射(ORM)库,它允许开发者使用Python类来操作数据库。ORM使得数据库操作更接近面向对象编程,减少了与SQL的直接交互,提高了开发效率和代码可读性。SQLAlchemy2_stubs库为...

    PyPI 官网下载 | sqlalchemy-postgresql-json-0.4.7.tar.gz

    SQLAlchemy是Python中广泛使用的对象关系映射(ORM)工具,它允许开发人员使用Python类和对象来操作数据库,从而减少了与SQL语言的直接交互。ORM使得在多种数据库系统间切换变得更加容易,同时保持代码的可读性和可...

Global site tag (gtag.js) - Google Analytics