Skip to content

Latest commit

 

History

History
35 lines (32 loc) · 1.76 KB

README.md

File metadata and controls

35 lines (32 loc) · 1.76 KB

0x0F. Python - Object-relational mapping

Resources Read or watch:

  • Object-relational mappers
  • mysqlclient/MySQLdb documentation (please don’t pay attention to _mysql)
  • MySQLdb tutorial
  • SQLAlchemy tutorial
  • SQLAlchemy
  • mysqlclient/MySQLdb
  • Introduction to SQLAlchemy
  • Flask SQLAlchemy
  • 10 common stumbling blocks for SQLAlchemy newbies
  • Python SQLAlchemy Cheatsheet
  • SQLAlchemy ORM Tutorial for Python Developers (Warning: This tutorial is with PostgreSQL, but the concept of SQLAlchemy is the same with MySQL)
  • SQLAlchemy Tutorial

Requirements

  • General
  • Allowed editors: vi, vim, emacs
  • All your files will be interpreted/compiled on Ubuntu 20.04 LTS using python3 (version 3.8.5)
  • Your files will be executed with MySQLdb version 2.0.x
  • Your files will be executed with SQLAlchemy version 1.4.x
  • All your files should end with a new line
  • The first line of all your files should be exactly #!/usr/bin/python3
  • A README.md file, at the root of the folder of the project, is mandatory
  • Your code should use the pycodestyle (version 2.8.*)
  • All your files must be executable
  • The length of your files will be tested using wc
  • All your modules should have a documentation (python3 -c 'print(import("my_module").doc)')
  • All your classes should have a documentation (python3 -c 'print(import("my_module").MyClass.doc)')
  • All your functions (inside and outside a class) should have a documentation (python3 -c 'print(import("my_module").my_function.doc)' and python3 -c 'print(import("my_module").MyClass.my_function.doc)')
  • A documentation is not a simple word, it’s a real sentence explaining what’s the purpose of the module, class or method (the length of it will be verified)
  • You are not allowed to use execute with sqlalchemy