那些年被我坑过的Python——牵一发动全身 第十一章MySQL、ORM
#!/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的更多相关文章
- 《Python 学习手册4th》 第十一章 赋值、表达式和打印
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...
- Python:从入门到实践--第十一章--测试代码--练习
#1.城市和国家:编写一个函数,它接受两个形参:一个城市名和一个国家名. #这个函数返回一个格式为City,Country的字符串,如Santiago,Chile.将这个函数 #存储在一个名为city ...
- Python黑帽编程 2.0 第二章概述
Python黑帽编程 2.0 第二章概述 于 20世纪80年代末,Guido van Rossum发明了Python,初衷据说是为了打发圣诞节的无趣,1991年首次发布,是ABC语言的继承,同时也是一 ...
- 使用Python将Excel中的数据导入到MySQL
使用Python将Excel中的数据导入到MySQL 工具 Python 2.7 xlrd MySQLdb 安装 Python 对于不同的系统安装方式不同,Windows平台有exe安装包,Ubunt ...
- Python MySQL ORM QuickORM hacking
# coding: utf-8 # # Python MySQL ORM QuickORM hacking # 说明: # 以前仅仅是知道有ORM的存在,但是对ORM这个东西内部工作原理不是很清楚, ...
- Python网络数据采集3-数据存到CSV以及MySql
Python网络数据采集3-数据存到CSV以及MySql 先热热身,下载某个页面的所有图片. import requests from bs4 import BeautifulSoup headers ...
- 编程入门视频【 Python、PHP、ThinkPHP、Laravel、Mysql、微信小程序】
免费分享 Python.PHP.ThinkPHP.Laravel.Mysql.微信小程序等学习视频 点击进入搜刮 免费分享 Python.PHP.ThinkPHP.Laravel.Mysql.微信小程 ...
- 《python for data analysis》第七章,数据规整化
<利用Python进行数据分析>第七章的代码. # -*- coding:utf-8 -*-# <python for data analysis>第七章, 数据规整化 imp ...
- 《python for data analysis》第五章,pandas的基本使用
<利用python进行数据分析>一书的第五章源码与读书笔记 直接上代码 # -*- coding:utf-8 -*-# <python for data analysis>第五 ...
随机推荐
- Day 16: Goose Extractor —— 好用的文章提取工具
Day 16: Goose Extractor -- 好用的文章提取工具 Day 16: Goose Extractor -- 好用的文章提取工具
- 你不一定能做对的JavaScript闭包面试题
由工作中演变而来的面试题 这是一个我工作当中的遇到的一个问题,似乎很有趣,就当做了一道题去面试,发现几乎没人能全部答对并说出原因,遂拿出来聊一聊吧. 先看题目代码: function fun(n,o) ...
- Broken line - SGU 124(判断点与多边形的关系)
题目大意:RT 分析:构造一条射线,如果穿越偶数条边,那么就在多边形外面,如果穿越奇数条边,那么就在多边形里面. 代码如下: ===================================== ...
- mahout算法源码分析之Collaborative Filtering with ALS-WR拓展篇
Mahout版本:0.7,hadoop版本:1.0.4,jdk:1.7.0_25 64bit. 额,好吧,心头的一块石头总算是放下了.关于Collaborative Filtering with AL ...
- 用ChooseALicense帮自己选一个开源license,然后用AddALicense给自己的github自动加上license文件
在我之前的一篇博客里面介绍过tl;drLegal ——开源软件license的搜索引擎,可以很方便的查询各种license,并且给出了很简洁的解释.今天又发现了另外一个帮助你选择你的开源软件licen ...
- Spring与Ibatis整合入门
Ibatis作为一个将java对象与sql中的数据进行映射的工具,可以将一个应用中常用的sql操作抽象为模版,在应用后续与数据库的交互中,将输入sql语句简化为更改一部分参数. ibatis整合到sp ...
- android中选择控件与选择界面自然过度效果的实现--一种新的交互设计
转载请标明出处: http://blog.csdn.net/jianghejie123/article/details/40648931 在安卓中经常遇到须要选择一个东西的功能,比方选择日期.选择文件 ...
- android 09
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools=&q ...
- LINUX启动顺序
Linux 启动顺序: 1. BIOS自检 (服务器硬件启动的第一步,坑定的啦) 2. 运行系统内核并检测硬件(这个是看系统了,redhat等相关版本是通过/boot/vm进行启动 vmlinuz) ...
- [Redis] windows下安装 Redis
一:Redis是什么? Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 通过https://github.c ...