1.多张表映射到一个类

import pandas as pd
from settings import DATABASES
from sqlalchemy import create_engine
import sqlalchemy.orm
import sqlalchemy.ext.declarative

metadata = sqlalchemy.MetaData()

STK_BASIC_INFO_table = sqlalchemy.Table('quant_stk_basic_info', metadata,
                                  sqlalchemy.Column('STK_UNI_CODE', sqlalchemy.Integer, primary_key = True),
                                  sqlalchemy.Column('STK_CODE', sqlalchemy.String(23)),
                                  )

FCT_VALUE_ROW_Q_table = sqlalchemy.Table('quant_fct_value_row_q',metadata,
                                 
sqlalchemy.Column('SEC_UNI_CODE', sqlalchemy.Integer,
sqlalchemy.ForeignKey('quant_stk_basic_info.STK_UNI_CODE'),primary_key=True),
                                  sqlalchemy.Column("END_DATE", sqlalchemy.Date),
                                  sqlalchemy.Column("A7041000005", sqlalchemy.Float),

            )

j_Q = sqlalchemy.join(STK_BASIC_INFO_table, FCT_VALUE_ROW_Q_table)

#首先需要生成一个BaseModel类,作为所有模型类的基类
BaseModel = sqlalchemy.ext.declarative.declarative_base()

#构建 数据模型 Factor
class Factor_Q(BaseModel):
    __table__ = j_Q
    gp_unicode = sqlalchemy.orm.column_property(STK_BASIC_INFO_table.c.STK_UNI_CODE, FCT_VALUE_ROW_Q_table.c.SEC_UNI_CODE)
    gpcode = STK_BASIC_INFO_table.c.STK_CODE
    date = FCT_VALUE_ROW_Q_table.c.END_DATE
    ACC_PAY_TDAYS = FCT_VALUE_ROW_Q_table.c.A7041000005

# 利用Session对象链接数据库

self._engine_mysql = create_engine(
            DATABASES["Quant"].get("engine") + "://" + DATABASES["Quant"].get("user") + ":" + DATABASES[
                "Quant"].get("password") + "@" + DATABASES["Quant"].get("host") + "/" + DATABASES["Quant"].get(
                "db") + "?charset=utf8")
DBSession = sqlalchemy.orm.sessionmaker(bind=self._engine_mysql)  # 创建回话类
session = DBSession()  # 创建回话对象

q = session.query(Factor_Q.ACC_PAY_TDAYS).filter(Factor_Q.gpcode.in_(['002252.XSHE','002253.XSHE']))

for data in q:

  print data

2.单张表映射到一个类

# 首先需要生成一个BaseModel类,作为所有模型类的基类
BaseModel = sqlalchemy.ext.declarative.declarative_base()

# 构建数据模型 FIN_IDX_ANA
class FIN_IDX_ANA(BaseModel):
    __tablename__ = 'fin_idx_ana'  # 表名
    __table_args__ = (
        PrimaryKeyConstraint('COM_UNI_CODE', 'END_DATE'),
    )

    # 表结构
    com_unicode = sqlalchemy.Column("COM_UNI_CODE", sqlalchemy.Integer)
    gpcode = sqlalchemy.Column("STK_CODE", sqlalchemy.String(10), nullable=False)
    date = sqlalchemy.Column("END_DATE", sqlalchemy.Date)
    BEPS = sqlalchemy.Column("BEPS", sqlalchemy.Float, default=0)

之后的调用方法和上面1的一样。

Demo:

  百度云(13207134391)

  Python/sqlalchemy

sqlalchemy 映射的小例子的更多相关文章

  1. springmvc入门的第一个小例子

    今天我们探讨一下springmvc,由于是初学,所以简单的了解一下 springmvc的流程,后续会持续更新... 由一个小例子来简单的了解一下 springmvc springmvc是spring框 ...

  2. sbrk与brk的使用小例子

    sbrk() 和 brk() - Unix的系统函数   sbrk()和brk() 系统的底层会维护一个位置,通过位置的移动完成内存的分配和回收.映射内存时 以一个内存页作为基本单位.   void* ...

  3. php+jquery+ajax+json简单小例子

    直接贴代码: <html> <title>php+jquery+ajax+json简单小例子</title> <?php header("Conte ...

  4. spring-mvc-两个个小例子

    1.用Eclipse创建一个工程,命名为spring2.0 并添加相应的jar包(我用的是4.0.5的版本)到 lib 包下: spring-webmvc-4.0.5.RELEASE.jar spri ...

  5. Spring和Hibernate结合的一个小例子

    1.新建一个SpringHibernate的maven项目 2.pom文件的依赖为 <dependency> <groupId>junit</groupId> &l ...

  6. Spring.Net在ASP.NET Mvc里使用的一个小例子

    就贴个小例子,就不注意格式了. 1.下载dll NuGet的下载地址:http://docs.nuget.org/docs/start-here/installing-nuget 在vs的NuGet里 ...

  7. java即时通信小例子

    学习java一段时间了,今天写来一个即时通信的小例子练手在其过程中也学到了一些知识拿出来和大家分享,请路过的各位大神多多赐教... 好了下面讲一下基本的思路: 首先,编写服务器端的程序,简单点说吧就是 ...

  8. Runtime的几个小例子(含Demo)

    一.什么是runtime(也就是所谓的“运行时”,因为是在运行时实现的.)           1.runtime是一套底层的c语言API(包括很多强大实用的c语言类型,c语言函数);  [runti ...

  9. bootstrap 模态 modal 小例子

    bootstrap 模态 modal  小例子 <html> <head> <meta charset="utf-8" /> <title ...

随机推荐

  1. ASP.NET Zero--9.一个例子(2)商品分类管理-列表

    1.创建实体类 参考:http://www.cnblogs.com/farb/p/4923137.html 在Core(领域层)项目下新建一个目录Entities,在此目录下新建一个Category类 ...

  2. Flexible 弹性盒子模型之CSS justify-content 属性

    实例 在弹性盒对象的 <div> 元素中的各项周围留有空白: div { display: flex; justify-content: space-around; } 复制 效果预览 浏 ...

  3. Angularjs通过$http与服务器通信

    angular是一个前端框架,实现了可交互式的页面,但是对于一个web应用,页面上进行展示的数据从哪里来,肯定需要服务端进行支持,那么angular是如何同服务端进行交互的呢? $http angul ...

  4. Form 提交表单

    ---HTML <form action="/Sample/SampleList/ExportSample" style="display:inline" ...

  5. CentOS7安装完毕,重新开机启动后显示: Initial setup of CentOS Linux 7 (core)

    CentOS7安装完毕,重新开机启动后显示: Initial setup of CentOS Linux 7 (core) 1) [x] Creat user 2) [!] License infor ...

  6. 石头剪刀布 OpenJudge 1.6.08

    石头剪刀布是常见的猜拳游戏.石头胜剪刀,剪刀胜布,布胜石头.如果两个人出拳一样,则不分胜负. 一天,小A和小B正好在玩石头剪刀布.已知他们的出拳都是有周期性规律的,比如:"石头-布-石头-剪 ...

  7. Long类型比较大小,long型和Long型区别

    今天写代码发现发现本地程序是正常的,但是发送到测试环境就不正常了,本着对数据的怀疑态度链接了测试数据库,调试程序发现,确实是数据问题,然后数据出现在什么地方呢?才发现是在判断用户所属的teamGrou ...

  8. ASP.NET MVC Url中带点号出现404错误的解决方案

    由于项目需求,项目的路由设计如下 config.Routes.MapHttpRoute( name: "Get/Put Sku", routeTemplate: "api ...

  9. readonly属性在各浏览器中的区别

    有个项目需求是正常显示时为只读,不可修改: 点击修改按钮后,可修改表单元素. 首先想到的是readonly属性,其用于规定输入字段为只读,不能修改.在javascript中消除readonly值,可将 ...

  10. nyoj 79 拦截导弹 (动态规划)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=79 题意即求最长单调递减子序列 #include<iostream> #inc ...