Python.
И СУБД.
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
data:image/s3,"s3://crabby-images/0aa91/0aa9194fbc7f51baccb0bc937a3df623dd388b02" alt=""
Лекция #8
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Почему важно отмечаться на лекции?
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
data:image/s3,"s3://crabby-images/2bf8c/2bf8c8e5e25e45337c8ef5d0b9bfd3ec712ef73f" alt=""
notebook.ipynb
data:image/s3,"s3://crabby-images/413e7/413e7498e2f582464f6a123020d218f0a43bd1d3" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Рейтинг популярности
data:image/s3,"s3://crabby-images/5971b/5971b91c796a29c2f11ad92ae42d68e0ab0855b2" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Где хранить данные?
- На диске (HDD, SSD)
- В памяти (in-memory)
data:image/s3,"s3://crabby-images/341f9/341f93f9639428ff842fa14fc8e23f3ff6930121" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Модель хранения данных
- Реляционные бд
- Документ-ориентированные
- Key-value хранилища
- Графовые базы данных
- Time series
- Поисковые движки
- Другие
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
CAP-теорема
- Consistency
- Availability
- Partition tolerance
data:image/s3,"s3://crabby-images/604cd/604cd4c5efdfbddae08da51090c6c342e11c6c37" alt=""
Определение
data:image/s3,"s3://crabby-images/9f0be/9f0be6a16f01e9aad017d1330187eda7812f519c" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Общие понятия
- Язык запросов
- Индексы
- Транзакции
- ACID
- Миграции
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Способы масштабирования
- Вертикальное
- Горизонтальное
data:image/s3,"s3://crabby-images/52320/523201919e81dd119c41898b25841f62696f0382" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Репликация
data:image/s3,"s3://crabby-images/071b6/071b64f2f4ee0a2e5eb93f8ebc015ac20a605e87" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Шардинг
data:image/s3,"s3://crabby-images/b8019/b80191e4e23711a22f6699c47ab678a227ae0d27" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Популярность
data:image/s3,"s3://crabby-images/96d0f/96d0fa128d78ce57eebbea201f9debfcce152240" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Реляционные бд
data:image/s3,"s3://crabby-images/d3671/d367101d86ccde0be4bd4dadbb0265280d4831cb" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Таблицы, столбцы, строки
data:image/s3,"s3://crabby-images/15af2/15af2b547138fe4b2950f645c9f6063b739401a7" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
SQL
SELECT * FROM users;
INSERT INTO users (name, address)
VALUES ('Alexander','Stavanger, Norway');
UPDATE users SET address="Moscow, Russia"
WHERE name="Alexander";
DELETE FROM users WHERE name="Alexander";
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Первичные ключи
(Primary Key)
CREATE TABLE users (
id int NOT NULL AUTO_INCREMENT,
name varchar(255) NOT NULL,
address varchar(255),
PRIMARY KEY (id)
);
Уникально определяет каждую запись в таблице
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Внешние ключи (Foreign Key)
Основной примитив отношений - поле, ссылающееся на первичный ключ другой таблицы
CREATE TABLE City
(
id INTEGER NOT NULL PRIMARY KEY,
name CHAR(40)
)
CREATE TABLE Street
(
id INTEGER NOT NULL PRIMARY KEY,
name CHAR(40),
id_city INTEGER NOT NULL FOREIGN KEY REFERENCES City(id)
)
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Отношения (relations)
- Один к одному (One to One)
- Один ко многим/многие к одному (One to Many/Many to One)
- Многие ко многим (Many to Many)
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
JOINS
data:image/s3,"s3://crabby-images/37667/37667fd4ef96e9ae8bf5a965539b8f6a8a4eec8d" alt=""
data:image/s3,"s3://crabby-images/b17b7/b17b7342c3a9aa5bbd006a9f03d808f391a75376" alt=""
data:image/s3,"s3://crabby-images/d7dcd/d7dcdac00b9701a46da2d8ecdb0338515cc9cd12" alt=""
user:
course:
https://www.sitepoint.com/understanding-sql-joins-mysql-database/
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
INNER JOIN (JOIN)
SELECT user.name, course.name
FROM `user`
INNER JOIN `course` on user.course = course.id;
data:image/s3,"s3://crabby-images/c7eff/c7effa08acec131442aeaac99d27c1a43f044e74" alt=""
data:image/s3,"s3://crabby-images/7bb57/7bb57c132951cb0c4553045b9dbb1c9c7bfdd784" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
LEFT JOIN
SELECT user.name, course.name
FROM `user`
LEFT JOIN `course` on user.course = course.id;
data:image/s3,"s3://crabby-images/9a02f/9a02ff8eeb292601e136515097491870cf31731b" alt=""
data:image/s3,"s3://crabby-images/f792b/f792bd197936ef7b937798d348e51728bbc9272e" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Python – работа с реляционными бд
- Нативные коннекторы (mysqlclient, sqlite3, psycopg2). DB API 2.0
- ORM (SQLAlchemy, Peewee, Django ORM)
data:image/s3,"s3://crabby-images/1d9ec/1d9ec3193006746cc0f2b19dc0e089d3b2b991e6" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Document-oriented
data:image/s3,"s3://crabby-images/3a344/3a3447fd7566b1ab5e4be03b805e882ac24f9de7" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Преимущества
- Отсутствие схемы (хранение только нужных атрибутов, гибкость)
- Возможность быстрой записи
- Проще шардировать данные
Эти преимущества могут быть и недостатками - "know your business"
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
PyMongo
from pymongo import MongoClient
client = MongoClient()
db = client.test
result = db.restaurants.insert_one(
{
"address": {
"street": "2 Avenue",
"zipcode": "10075",
"building": "1480",
"coord": [-73.9557413, 40.7720266]
},
"grades": ["A", "B"]
}
)
cursor = db.restaurants.find({"address.zipcode": "10075"})
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Поисковые движки
data:image/s3,"s3://crabby-images/3602d/3602dbd55f45d1dbfaa27e6ba855977eb0bef30d" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Time-series
data:image/s3,"s3://crabby-images/97793/97793952b2861c314e19137396ddb144f0a7337d" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Отправка в Graphite
import socket
import time
CARBON_SERVER = '127.0.0.1'
CARBON_PORT = 2003
ts = int(time.time()
message = 'passkeeper.response_time 420 %d\n' % ts)
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((CARBON_SERVER, CARBON_PORT))
sock.sendall(message)
sock.close()
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Grafana
data:image/s3,"s3://crabby-images/ce1c9/ce1c948d96d239ea763020d5be093cd277f857f9" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Column-oriented
data:image/s3,"s3://crabby-images/2dc0b/2dc0ba0c5371dd6eba8dcffaf0d4868ae3f275f2" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Преимущества
data:image/s3,"s3://crabby-images/d119c/d119ca365d7c2acca17cad3495a39eb4b3f0a6b2" alt=""
data:image/s3,"s3://crabby-images/ca823/ca823e129b325a0fbabae3fa6bb2ff85a653427f" alt=""
data:image/s3,"s3://crabby-images/600bf/600bf89b89a8b751b5ff1bb77d11a4dac0647927" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
cassandra-driver
from cassandra.cluster import Cluster
from cassandra.policies import RoundRobinPolicy
from cassandra.query import SimpleStatement
cluster = Cluster(
['10.1.1.3', '10.1.1.4', '10.1.1.5'],
load_balancing_policy=RoundRobinPolicy(),
port=9042)
session = cluster.connect('mykeyspace')
rows = session.execute('SELECT name, age, email FROM users')
for user_row in rows:
print user_row.name, user_row.age, user_row.email
query = SimpleStatement(
"INSERT INTO users (name, age) VALUES (%s, %s)",
consistency_level=ConsistencyLevel.QUORUM)
session.execute(query, ('John', 42))
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Key-value
data:image/s3,"s3://crabby-images/5ef47/5ef47b3ce9479ddf6c0419224513c7ff4db5493a" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Другие интересные бд
- RocksDB
- CockroachDB
- Tarantool
- Aerospike
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Python – работа с NoSQL бд
Свой коннектор для каждой базы данных, никакой абстракции
data:image/s3,"s3://crabby-images/7b3e8/7b3e885f099eed48c121b02259bab072c061031f" alt=""
data:image/s3,"s3://crabby-images/201f2/201f2b4e076da4353292ea7ebc19063ec0eca52a" alt=""
Спасибо!
Python_10
By Emelin Alexander
Python_10
- 1,037