Source code for core.orms.meetup_orm

'''
Meetup
======


'''

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.dialects.mysql import VARCHAR, BIGINT, TEXT, DECIMAL
from sqlalchemy.types import JSON, INT, TIMESTAMP
from sqlalchemy import Column, ForeignKey
from sqlalchemy.orm import relationship

Base = declarative_base()

[docs]class Group(Base): __tablename__ = 'meetup_groups' id = Column(BIGINT(20), primary_key=True, autoincrement=False) urlname = Column(VARCHAR(200), unique=True) category_name = Column(VARCHAR(50)) category_shortname = Column(VARCHAR(50)) city = Column(VARCHAR(100)) country = Column(VARCHAR(100)) created = Column(BIGINT(20)) description = Column(TEXT(collation="utf8mb4_unicode_ci")) lat = Column(DECIMAL(6, 3)) lon = Column(DECIMAL(6, 3)) members = Column(INT) name = Column(TEXT(collation="utf8mb4_unicode_ci")) topics = Column(JSON) category_id = Column(INT) country_name = Column(VARCHAR(100)) timestamp = Column(TIMESTAMP)
[docs]class GroupMember(Base): '''Note: no foreign key constraint, since unknown groups will be found in the member expansion phase''' __tablename__ = 'meetup_groups_members' group_id = Column(BIGINT(20), primary_key=True) group_urlname = Column(VARCHAR(200)) member_id = Column(BIGINT(20), primary_key=True)