#!/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. jQuery各种效果举例

    jQuery 所有jQuery详细使用说明请见:http://www.php100.com/manual/jquery/ jQuery的作用是操作浏览器html,从而达到用户的可视化效果,按照功能可分 ...

  2. there be 句型

    there be 意思:表示存在或者发生. 英文释义:used to show that sth exists or happens 如果现在进行时,单数时用is,复数时用are. 现在我问你一个问题 ...

  3. .\Obj\main.axf: Error: L6406E: No space in execution regions with .ANY selector matching sin_i.o(.co

    这个问题原因是 芯片的 空间不足 解决方法是  在KEIL 的DEVICE中选择 更大的空间的芯片型号

  4. C# ToString格式大全

      C# 货币  2.5.ToString("C"); // ¥2.50 // D 10进制数 25.ToString("D5"); // 25000 // E ...

  5. highcharts动态获取数据生成图表问题

    动态获取数据说白点就是从后台传值到前台,前台把这些值赋值给x轴与y轴(这里指的是你X轴与Y轴都是变化的数据,如果你的X轴是固定的,像时间等等的那就另说).  柱状图的动态传值: //获取后台数据 va ...

  6. thinkphp框架dump友好调试输出函数

    /** * 浏览器友好的变量输出 * @param mixed $var 变量 * @param boolean $echo 是否输出 默认为True 如果为false 则返回输出字符串 * @par ...

  7. c#基础语言编程-正则表达式基础

    引言 正则表达式是一种用高度抽象的字符串来描述字符串特征,进而实现对字符串的匹配.提取.替换等等.正则表达式(以下简称正则,Regex)通常不独立存在,各种编程语言和工具作为宿主语言提供对正则的支持, ...

  8. VS2012的安装项目只能用InstallShield Limited Edition[附资源下载]

    以前版本的Visual Stuido中安装项目都可以使用微软自家的Visual Studio Installer,但是到了VS2012这一切都变了,只能用InstallShield Limited E ...

  9. 看个人思路吧,清晰的话就简单 CodeForces 271A - Beautiful Year

    It seems like the year of 2013 came only yesterday. Do you know a curious fact? The year of 2013 is ...

  10. qt中使用opencv处理图片 QImage 和 IplImage 相互之间转换问题

    在用opencv处理图片显示在qt label上的时候遇到不是问题 1. qt上要用qimage形式才干显示 IplImage转成 Qimage 彩色图像转换 IplImage  *fram; QIm ...