#!/usr/bin/env python
# -*- coding:utf-8 -*-
__Author__ = "Zhang Xuyao" from sqlalchemy import create_engine # engine = create_engine("mysql+pymysql://root:123123@localhost/attendance?charset=utf8", echo=True)
engine = create_engine("mysql+pymysql://root:123123@localhost/attendance?charset=utf8")

engine

 #!/usr/bin/env python
# -*- coding:utf-8 -*-
__Author__ = "Zhang Xuyao" from sqlalchemy.ext.declarative import declarative_base
from settings import db_settings
from sqlalchemy import Table, Column, Integer, String, Enum, DATE, ForeignKey, PrimaryKeyConstraint
from sqlalchemy.orm import relationship Base = declarative_base() teacherBatch_t = Table('tbt', Base.metadata,
Column('batch_name', String(64), ForeignKey('batch.name')),
Column('teacher_id', String(64), ForeignKey('teacher.id'))
) studentBatch_t = Table('sbt', Base.metadata,
Column('batch_name', String(64), ForeignKey('batch.name')),
Column('student_qq', String(64), ForeignKey('student.qq'))
) class Teacher(Base):
__tablename__ = 'teacher'
id = Column(String(64), primary_key=True)
name = Column(String(64), nullable=False)
password = Column(String(64), nullable=False, default='321cba') # tstudents = relationship('Student', secondary=task_t, backref='teachers')
tbatchs = relationship('Batch', secondary=teacherBatch_t, backref='teachers') def __repr__(self):
return self.name class Student(Base):
__tablename__ = 'student'
qq = Column(String(64), primary_key=True)
name = Column(String(64), nullable=False)
password = Column(String(64), nullable=False, default='321cba') # steachers = relationship('Teacher', secondary=task_t, backref='students')
sbatchs = relationship('Batch', secondary=studentBatch_t, backref='students') def __repr__(self):
return self.name # 课程批次(班级)name为批次如python14期,courseType为类型如python
class Batch(Base):
__tablename__ = 'batch'
name = Column(String(64), primary_key=True)
courseType = Column(String(64), nullable=False) def __repr__(self):
return self.name + self.courseType class Task(Base):
__tablename__ = 'task'
batch_name = Column(String(64), ForeignKey('batch.name'))
date = Column(DATE, nullable=False)
student_qq = Column(String(64), ForeignKey('student.qq')) status = Column(Enum('at', 'ab', 'va', 'ot'),
default='ab', nullable=False)
score = Column(Integer,
default=0, nullable=False)
teacher_id = Column(String(64), ForeignKey('teacher.id')) comment = Column(String(1024))
task_pk = PrimaryKeyConstraint(batch_name, student_qq, date) student = relationship('Student', backref='tasks')
teacher = relationship('Teacher', backref='tasks') # 父类调用所有的子类实现表结构的创建##### # Base.metadata.drop_all(db_settings.engine) # 删除表结构
Base.metadata.create_all(db_settings.engine) # 创建表结构

tables relationship

 #!/usr/bin/env python
# -*- coding:utf-8 -*-
__Author__ = "Zhang Xuyao" from settings import db_tables as dbt
from settings import db_settings
from sqlalchemy.orm import sessionmaker
from sqlalchemy import desc,func
import datetime Session_class = sessionmaker(bind=db_settings.engine) # 创建与数据库的会话session class ,注意,这里返回给session的是个class,不是实例
db = Session_class() # 生成session实例 def teacherAuth(id, password):
obj = db.query(dbt.Teacher).filter(dbt.Teacher.id == id).first()
if not obj:
return False
if password == obj.password:
# print("got it")
return obj
else:
return False def studentAuth(qq, password):
obj = db.query(dbt.Student).filter(dbt.Student.qq == qq).first()
if not obj:
return False
if password == obj.password:
# print("got it")
return obj
else:
return False def addTeacher(id, name, password='abc123'):
obj = dbt.Teacher(id=id, name=name, password=password)
db.add(obj)
db.commit()
return obj def batchBindTeacher(id, name, password):
pass def addStudent(qq, name, password='abc123'):
obj = dbt.Student(qq=qq, name=name, password=password)
db.add(obj)
db.commit()
return obj def batchBindStudent(id, name, password):
pass def addBatch(name, courseType):
obj = dbt.Batch(name=name, courseType=courseType)
db.add(obj)
db.commit()
return obj def addTask(date, score='N/A', status='absent'):
pass if __name__ == '__main__':
t1 = addTeacher('t001', "Alex", "Alex123")
t2 = addTeacher('t002', "Jack", "Jack123")
t3 = addTeacher('t003', "Rain", "Rain123")
#
s1 = addStudent('s001', "chenronghua", "abc123")
s2 = addStudent('s002', "niuhanyang", "abc123")
s3 = addStudent('s003', "wangsen", "abc123")
#
b1 = addBatch("python14", "python")
b2 = addBatch("pythonS2", "python")
b3 = addBatch("Ops10", "Linux") b1.students = [s1, s2, s3]
b1.teachers = [t1, t2] for i in b1.students:
obj = dbt.Task(date='2016-10-26', teacher_id=t1.id, student_qq=i.qq, batch_name=b1.name)
db.add(obj)
db.commit()
#
# obj = db.query(dbt.Teacher).filter(dbt.Teacher.id == "t001").first()
# for i in obj.tbatchs:
# if i.name == 'python14':
# for j in i.students:
# if j.qq == 's001':
# print(j.name, j.password) pass

db handler

那些年被我坑过的Python——牵一发动全身 第十一章MySQL、ORM的更多相关文章

  1. 《Python 学习手册4th》 第十一章 赋值、表达式和打印

    ''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...

  2. Python:从入门到实践--第十一章--测试代码--练习

    #1.城市和国家:编写一个函数,它接受两个形参:一个城市名和一个国家名. #这个函数返回一个格式为City,Country的字符串,如Santiago,Chile.将这个函数 #存储在一个名为city ...

  3. Python黑帽编程 2.0 第二章概述

    Python黑帽编程 2.0 第二章概述 于 20世纪80年代末,Guido van Rossum发明了Python,初衷据说是为了打发圣诞节的无趣,1991年首次发布,是ABC语言的继承,同时也是一 ...

  4. 使用Python将Excel中的数据导入到MySQL

    使用Python将Excel中的数据导入到MySQL 工具 Python 2.7 xlrd MySQLdb 安装 Python 对于不同的系统安装方式不同,Windows平台有exe安装包,Ubunt ...

  5. Python MySQL ORM QuickORM hacking

    # coding: utf-8 # # Python MySQL ORM QuickORM hacking # 说明: # 以前仅仅是知道有ORM的存在,但是对ORM这个东西内部工作原理不是很清楚, ...

  6. Python网络数据采集3-数据存到CSV以及MySql

    Python网络数据采集3-数据存到CSV以及MySql 先热热身,下载某个页面的所有图片. import requests from bs4 import BeautifulSoup headers ...

  7. 编程入门视频【 Python、PHP、ThinkPHP、Laravel、Mysql、微信小程序】

    免费分享 Python.PHP.ThinkPHP.Laravel.Mysql.微信小程序等学习视频 点击进入搜刮 免费分享 Python.PHP.ThinkPHP.Laravel.Mysql.微信小程 ...

  8. 《python for data analysis》第七章,数据规整化

    <利用Python进行数据分析>第七章的代码. # -*- coding:utf-8 -*-# <python for data analysis>第七章, 数据规整化 imp ...

  9. 《python for data analysis》第五章,pandas的基本使用

    <利用python进行数据分析>一书的第五章源码与读书笔记 直接上代码 # -*- coding:utf-8 -*-# <python for data analysis>第五 ...

随机推荐

  1. CentOS让root用户可以SSH登录

    一.说明     Solaris 10 出于安全原因,默认参数很严格,禁止root用户直接使用ssh登陆 二.处理     1.可以先用非root的帐户,登陆到ssh后,su成root     2.如 ...

  2. 320. Generalized Abbreviation

    首先想到的是DFS,对于每个单词的字母都遍历,比如 spy: 1py,s1y,sp1 然后每个遍历完的单词再DFS..左右有数字就合并比如 1py: 11y=>2py, 1p1 这样.. 但是单 ...

  3. 查看线程linux cpu使用率

    Linux下如何查看高CPU占用率线程 LINUX CPU利用率计算 转 http://www.cnblogs.com/lidabo/p/4738113.html目录(?)[-] proc文件系统 p ...

  4. linux 监控命令

    先总结下常用的一些监控工具: ##linux命令 w 系统负载 lsof -p pid 进程打开的文件 lsof -i:port 端口的运行情况 free -m 内存情况 vmstat 进程.内存.内 ...

  5. 数据库事务的ACID和BASE

    ACID versus BASE for database transactions解释了ACID和BASE的区别.如下: ACID: (关系数据库) Atomic: 原子性,一个事务要么全部成功,要 ...

  6. flipsnap--手机屏幕水平滑动框架

    在很多手机应用中,大家都会见过这样一种效果:当手指横向滑动屏幕时,屏幕上的页面会向左或向右滑动. 下面介绍一下当用HTML5+CSS3开发手机应用时解决这类效果的一款js框架:flipsnap. fl ...

  7. Hadoop最基本的wordcount(统计词频)

    package com.uniclick.dapa.dstest; import java.io.IOException; import java.net.URI; import org.apache ...

  8. OPENSHIFT MYSQL使用Navicat连接配置

    最近一直在研究openshift免费空间的使用,对于如何用本地的数据库工具连接一直在找方法,呵呵,初学者. 以下方法可以实现: 1.在本地命令行中执行命令:rhc port-forward 应用名 如 ...

  9. Bootstrap-基于bootstrap的后台二级垂直菜单

    最近做一个后台的管理项目,用到了Twitter推出的bootstrap前端开发工具包,是一个基于css3/html5的框架.花周末时间,写了一个非常简单后台的菜单.首先,看一下菜单的结构: 预览地址  ...

  10. hadoop2.2 伪分布式环境

    在安装JDK之前,请确认系统是32还是64,根据系统版本,选择JDK版本.Hadoop版本 下面是以在CentOS-6.5-x86_64系统上安装为例 安装前准备 在"/usr"下 ...