Tornado——入门基础(三)数据模型

一:什么是数据模型?

  • 数据模型就是在程序中的自定义类型,主要目的是封装数据,封装自定义的数据,作为对象进行操作【封装】
  • 面向对象的封装零散的数据封装 ,封装属性/方法,最终以对象的形式呈现数据
  • 数据模型——>面向对象设计的class类型,就是面向对象中的类型,通过类型来表示一种模型【实体存在的物体——实体类】的过程。

二:ORM操作

1.ORM的理解?

  • ORM(Object Relational Mapping)对象关系映射,是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术——>程序中的对象object和数据库中的表(关系relation)之间的对应(mapping映射)关系,对于这样的关系操作管理过程就是orm!
  1. ORM的核心步骤
  • ORM的操作核心:数据对象的增删改查
  • ORM操作第一条:增删改
    增删改:都是直接操作数据库中数据记录的变动的
    ——>涉及到数据的增删改,数据的变动,故要接受事务管理 【commit()和rollback()】
  • ORM操作的第二条:查询
    查询:永远不变的核心,查询操作比增删改更加复杂的一种操作形式,ORM框架中一般都会将查询封装为单独的一部分进行处理!

3.ORM和tornado的关系

  • tornado曾经支持简单的ORM操作,通过自定义的SQL语句的方式,来完成数据对象的拆分之后进行的增删改查操作【并不是面向对象的】。后来因为torndb作为一个独立的模块进行处理,tornado不在有内置的ORM支持!
  • tornado在实际使用的时候人们都认为它并没有支持内置的ORM操作,需要和第三方模块结合起来完成数据模型对象的ORM操作【ps:这样的操作方式一般都是直接操作SQL语句】
    比较常用的操作:使用pymysql/tornado/sqlalchemy

4.sqlalchemy操作

  • windows环境下安装
    pip install sqlalchemy
    or
    easy_install sqlalchemy
  • 检测是否安装成功
    python环境下
    >>import sqlalchemy
    >>sqlalchemy.__version__
    >>1.2.0b3
    安装成功了
  • sqlalchemy的使用
    ——>ORM操作的核心,就是将程序中的对象要在数据库中进行增删改查操作

  • 1.连接指定的数据库
    建立指定数据库的连接引擎
    from sqlalchemy import create_engine#引入引擎对象的模块
    from sqlalchemy.orm import sessionmaker#创建和数据库连接会话模块
    engine = create_engine('.....')#创建引擎对象
    Session = sessionmaker(bind=engine)#创建会话类型
    session = Session()#获取一个会话连接

ps:如果创建会话的时候还没有创建引擎对象
Session = sessionmake()#创建一个会话类型
Session.configur(bind=engine)#将一个连接引擎注册给这个会话
session = Session()#得到具体的包含连接引擎会话

ps注意:sqlalchemy默认底层使用mysqldb完成和数据库的连接但是mysqldb不支持最新的版本的python和mysql数据库的连接,一般使用pymysql进行替代。
  • 2.数据模型创建对象——>sqlalchemy内建了一部分字段属性的函数和构建一个基础类的函数,可以自定义类型直接定义属性eg:Column用来定义属性,String/Integer/Float等等用来定义属性的类型。
    from sqlalchemy.ext.declarative import declarative_base
    from sqlalchemy import Column,String,Integer
    Base = declarative_base()
    image.png

    sqlalchemy不会自动关联数据模型和数据库中表的关系,需要在代码中直接指定当前类型和哪个数据库之间有关系通过tablename指定
    class Person(Base):
    __tablename__ ='persons'#指定关联的表
  • 3创建一个指定的数据对象
    和常规对象的创建方式一致,通过关键字参数直接给属性赋值
  • 此时创建的对象只是存在内存中的对象-没有id编号-暂时不受sqlalchemy的管理—临时对象
    person = Person(name='tom',age=12)
  • 同步对象数据到数据库,此时的同步,在数据库中并没有数据,而是临时存储在会话中的一个对象-—缓存对象
    session.add(person)
  • 通过事务提交的方式,将缓存对象可以存储到数据库中,此时对象为—持久对象
    session.commit()
    小结:对象的三种状态:
    1.临时状态:临时对象,程序中直接创建的对象
    2.缓存状态:通过调用会话add()函数将一个对象添加到会话缓存中,此时对象接受会话管理,但是数据库中并没有数据
    3.持久状态:通过调用会话的commit()/flush()等各种提交/刷新的操作,将数据存到数据库中,此时程序中的这个对象就是持久对象
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容

  • 转载,觉得这篇写 SQLAlchemy Core,写得非常不错。不过后续他没写SQLAlchemy ORM... ...
    非梦nj阅读 5,387评论 1 14
  • ORM:Object Relation Mapping 程序中的对象Object和数据库中的表(关系Relatio...
    云Shen不知处阅读 904评论 0 0
  • Tornado 曾经支持简单的 ORM 操作!就是可以通过自定义 sql 语句的方式,来完成数据对象的的增删改查操...
    依旧丶森阅读 4,119评论 0 4
  • 本文提炼于网络文章+个人提炼总结。 一、对比(Contrast) 找出PPT重点内容,然后彻底对比。对比可通过:字...
    陈焕佳阅读 228评论 0 0
  • 是一场梦/还是一场梦魇/最重要的是过程/最难的是做人/靠贩卖梦想为生/是不是也要出卖灵魂/做完了交易就不能再被称作...
    雀舞阅读 242评论 0 1