mirror of
https://github.com/veekun/pokedex.git
synced 2024-08-20 18:16:34 +00:00
Added a truckload of innerjoins and joinedloads.
Also reformatted the relationship definitions. Now less of a clusterfuck.
This commit is contained in:
parent
d90db39d43
commit
c519a4c824
1 changed files with 366 additions and 180 deletions
|
@ -440,9 +440,9 @@ class Generation(TableBase):
|
||||||
__singlename__ = 'generation'
|
__singlename__ = 'generation'
|
||||||
id = Column(Integer, primary_key=True, nullable=False, autoincrement=False,
|
id = Column(Integer, primary_key=True, nullable=False, autoincrement=False,
|
||||||
info=dict(description="A numeric ID"))
|
info=dict(description="A numeric ID"))
|
||||||
main_region_id = Column(Integer, ForeignKey('regions.id'),
|
main_region_id = Column(Integer, ForeignKey('regions.id'), nullable=False,
|
||||||
info=dict(description="ID of the region this generation's main games take place in"))
|
info=dict(description="ID of the region this generation's main games take place in"))
|
||||||
canonical_pokedex_id = Column(Integer, ForeignKey('pokedexes.id'),
|
canonical_pokedex_id = Column(Integer, ForeignKey('pokedexes.id'), nullable=False,
|
||||||
info=dict(description=u"ID of the Pokédex this generation's main games use by default"))
|
info=dict(description=u"ID of the Pokédex this generation's main games use by default"))
|
||||||
identifier = Column(Unicode(16), nullable=False,
|
identifier = Column(Unicode(16), nullable=False,
|
||||||
info=dict(description=u'An identifier', format='identifier'))
|
info=dict(description=u'An identifier', format='identifier'))
|
||||||
|
@ -1676,118 +1676,215 @@ class VersionGroupRegion(TableBase):
|
||||||
region_id = Column(Integer, ForeignKey('regions.id'), primary_key=True, nullable=False, autoincrement=False,
|
region_id = Column(Integer, ForeignKey('regions.id'), primary_key=True, nullable=False, autoincrement=False,
|
||||||
info=dict(description=u"The ID of the region."))
|
info=dict(description=u"The ID of the region."))
|
||||||
|
|
||||||
### Relations down here, to avoid ordering problems
|
|
||||||
|
### Relations down here, to avoid dependency ordering problems
|
||||||
|
|
||||||
Ability.changelog = relation(AbilityChangelog,
|
Ability.changelog = relation(AbilityChangelog,
|
||||||
order_by=AbilityChangelog.changed_in_version_group_id.desc(),
|
order_by=AbilityChangelog.changed_in_version_group_id.desc(),
|
||||||
backref='ability',
|
backref=backref('ability', innerjoin=True, lazy='joined'))
|
||||||
)
|
Ability.flavor_text = relation(AbilityFlavorText,
|
||||||
Ability.flavor_text = relation(AbilityFlavorText, order_by=AbilityFlavorText.version_group_id, backref='ability')
|
order_by=AbilityFlavorText.version_group_id,
|
||||||
Ability.generation = relation(Generation, backref='abilities')
|
backref=backref('ability', innerjoin=True, lazy='joined'))
|
||||||
|
Ability.generation = relation(Generation,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='abilities')
|
||||||
|
|
||||||
AbilityChangelog.changed_in = relation(VersionGroup, backref='ability_changelog')
|
AbilityChangelog.changed_in = relation(VersionGroup,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='ability_changelog')
|
||||||
|
|
||||||
AbilityFlavorText.version_group = relation(VersionGroup)
|
AbilityFlavorText.version_group = relation(VersionGroup,
|
||||||
AbilityFlavorText.language = relation(Language)
|
innerjoin=True)
|
||||||
|
AbilityFlavorText.language = relation(Language,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
Berry.berry_firmness = relation(BerryFirmness, backref='berries')
|
|
||||||
|
Berry.berry_firmness = relation(BerryFirmness,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='berries')
|
||||||
Berry.firmness = association_proxy('berry_firmness', 'name')
|
Berry.firmness = association_proxy('berry_firmness', 'name')
|
||||||
Berry.flavors = relation(BerryFlavor, order_by=BerryFlavor.contest_type_id, backref='berry')
|
Berry.flavors = relation(BerryFlavor,
|
||||||
Berry.natural_gift_type = relation(Type)
|
order_by=BerryFlavor.contest_type_id,
|
||||||
|
backref=backref('berry', innerjoin=True))
|
||||||
|
Berry.natural_gift_type = relation(Type, innerjoin=True)
|
||||||
|
|
||||||
BerryFlavor.contest_type = relation(ContestType)
|
BerryFlavor.contest_type = relation(ContestType, innerjoin=True)
|
||||||
|
|
||||||
ContestCombo.first = relation(Move, primaryjoin=ContestCombo.first_move_id==Move.id,
|
|
||||||
|
ContestCombo.first = relation(Move,
|
||||||
|
primaryjoin=ContestCombo.first_move_id==Move.id,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
backref='contest_combo_first')
|
backref='contest_combo_first')
|
||||||
ContestCombo.second = relation(Move, primaryjoin=ContestCombo.second_move_id==Move.id,
|
ContestCombo.second = relation(Move,
|
||||||
|
primaryjoin=ContestCombo.second_move_id==Move.id,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
backref='contest_combo_second')
|
backref='contest_combo_second')
|
||||||
|
|
||||||
Encounter.location_area = relation(LocationArea, backref='encounters')
|
|
||||||
Encounter.pokemon = relation(Pokemon, backref='encounters')
|
|
||||||
Encounter.version = relation(Version, backref='encounters')
|
|
||||||
Encounter.slot = relation(EncounterSlot, backref='encounters')
|
|
||||||
|
|
||||||
EncounterConditionValue.condition = relation(EncounterCondition, backref='values')
|
Encounter.condition_value_map = relation(EncounterConditionValueMap,
|
||||||
|
backref='encounter')
|
||||||
Encounter.condition_value_map = relation(EncounterConditionValueMap, backref='encounter')
|
|
||||||
Encounter.condition_values = association_proxy('condition_value_map', 'condition_value')
|
Encounter.condition_values = association_proxy('condition_value_map', 'condition_value')
|
||||||
|
Encounter.location_area = relation(LocationArea,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='encounters')
|
||||||
|
Encounter.pokemon = relation(Pokemon,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='encounters')
|
||||||
|
Encounter.version = relation(Version,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='encounters')
|
||||||
|
Encounter.slot = relation(EncounterSlot,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='encounters')
|
||||||
|
|
||||||
|
EncounterConditionValue.condition = relation(EncounterCondition,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='values')
|
||||||
EncounterConditionValueMap.condition_value = relation(EncounterConditionValue,
|
EncounterConditionValueMap.condition_value = relation(EncounterConditionValue,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
backref='encounter_map')
|
backref='encounter_map')
|
||||||
|
|
||||||
EncounterSlot.terrain = relation(EncounterTerrain, backref='slots')
|
EncounterSlot.terrain = relation(EncounterTerrain,
|
||||||
EncounterSlot.version_group = relation(VersionGroup)
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='slots')
|
||||||
|
EncounterSlot.version_group = relation(VersionGroup, innerjoin=True)
|
||||||
|
|
||||||
EvolutionChain.growth_rate = relation(GrowthRate, backref='evolution_chains')
|
|
||||||
EvolutionChain.baby_trigger_item = relation(Item, backref='evolution_chains')
|
|
||||||
|
|
||||||
Experience.growth_rate = relation(GrowthRate, backref='experience_table')
|
EvolutionChain.growth_rate = relation(GrowthRate,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='evolution_chains')
|
||||||
|
EvolutionChain.baby_trigger_item = relation(Item,
|
||||||
|
backref='evolution_chains')
|
||||||
|
|
||||||
Generation.canonical_pokedex = relation(Pokedex, backref='canonical_for_generation')
|
|
||||||
Generation.versions = relation(Version, secondary=VersionGroup.__table__)
|
|
||||||
Generation.main_region = relation(Region)
|
|
||||||
|
|
||||||
GrowthRate.max_experience_obj = relation(Experience, primaryjoin=and_(Experience.growth_rate_id == GrowthRate.id, Experience.level == 100), uselist=False)
|
Experience.growth_rate = relation(GrowthRate,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='experience_table')
|
||||||
|
|
||||||
|
|
||||||
|
Generation.canonical_pokedex = relation(Pokedex,
|
||||||
|
backref='canonical_for_generation')
|
||||||
|
Generation.versions = relation(Version,
|
||||||
|
secondary=VersionGroup.__table__,
|
||||||
|
innerjoin=True)
|
||||||
|
Generation.main_region = relation(Region, innerjoin=True)
|
||||||
|
|
||||||
|
|
||||||
|
GrowthRate.max_experience_obj = relation(Experience,
|
||||||
|
primaryjoin=and_(
|
||||||
|
Experience.growth_rate_id == GrowthRate.id,
|
||||||
|
Experience.level == 100),
|
||||||
|
uselist=False, innerjoin=True)
|
||||||
GrowthRate.max_experience = association_proxy('max_experience_obj', 'experience')
|
GrowthRate.max_experience = association_proxy('max_experience_obj', 'experience')
|
||||||
|
|
||||||
Item.berry = relation(Berry, uselist=False, backref='item')
|
|
||||||
Item.flags = relation(ItemFlag, secondary=ItemFlagMap.__table__)
|
Item.berry = relation(Berry,
|
||||||
Item.flavor_text = relation(ItemFlavorText, order_by=ItemFlavorText.version_group_id.asc(), backref='item')
|
uselist=False,
|
||||||
Item.fling_effect = relation(ItemFlingEffect, backref='items')
|
backref='item')
|
||||||
Item.machines = relation(Machine, order_by=Machine.version_group_id.asc())
|
Item.flags = relation(ItemFlag,
|
||||||
Item.category = relation(ItemCategory)
|
secondary=ItemFlagMap.__table__)
|
||||||
|
Item.flavor_text = relation(ItemFlavorText,
|
||||||
|
order_by=ItemFlavorText.version_group_id.asc(),
|
||||||
|
backref=backref('item', innerjoin=True, lazy='joined'))
|
||||||
|
Item.fling_effect = relation(ItemFlingEffect,
|
||||||
|
backref='items')
|
||||||
|
Item.machines = relation(Machine,
|
||||||
|
order_by=Machine.version_group_id.asc())
|
||||||
|
Item.category = relation(ItemCategory,
|
||||||
|
innerjoin=True,
|
||||||
|
backref=backref('items', order_by=Item.identifier.asc()))
|
||||||
Item.pocket = association_proxy('category', 'pocket')
|
Item.pocket = association_proxy('category', 'pocket')
|
||||||
|
|
||||||
ItemCategory.items = relation(Item, order_by=Item.identifier)
|
ItemCategory.pocket = relation(ItemPocket, innerjoin=True)
|
||||||
ItemCategory.pocket = relation(ItemPocket)
|
|
||||||
|
|
||||||
ItemFlavorText.version_group = relation(VersionGroup)
|
ItemFlavorText.version_group = relation(VersionGroup,
|
||||||
ItemFlavorText.language = relation(Language)
|
innerjoin=True, lazy='joined')
|
||||||
|
ItemFlavorText.language = relation(Language,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
ItemGameIndex.item = relation(Item, backref='game_indices')
|
ItemGameIndex.item = relation(Item,
|
||||||
ItemGameIndex.generation = relation(Generation)
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='game_indices')
|
||||||
|
ItemGameIndex.generation = relation(Generation,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
ItemPocket.categories = relation(ItemCategory, order_by=ItemCategory.identifier)
|
ItemPocket.categories = relation(ItemCategory,
|
||||||
|
innerjoin=True,
|
||||||
|
order_by=ItemCategory.identifier.asc())
|
||||||
|
|
||||||
Location.region = relation(Region, backref='locations')
|
|
||||||
|
|
||||||
LocationArea.location = relation(Location, backref='areas')
|
Location.region = relation(Region,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='locations')
|
||||||
|
|
||||||
|
LocationArea.location = relation(Location,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='areas')
|
||||||
|
|
||||||
|
LocationGameIndex.location = relation(Location,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='game_indices')
|
||||||
|
LocationGameIndex.generation = relation(Generation,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
LocationGameIndex.location = relation(Location, backref='game_indices')
|
|
||||||
LocationGameIndex.generation = relation(Generation)
|
|
||||||
|
|
||||||
Machine.item = relation(Item)
|
Machine.item = relation(Item)
|
||||||
Machine.version_group = relation(VersionGroup)
|
Machine.version_group = relation(VersionGroup,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
|
|
||||||
Move.changelog = relation(MoveChangelog,
|
Move.changelog = relation(MoveChangelog,
|
||||||
order_by=MoveChangelog.changed_in_version_group_id.desc(),
|
order_by=MoveChangelog.changed_in_version_group_id.desc(),
|
||||||
backref='move',
|
backref=backref('move', innerjoin=True, lazy='joined'))
|
||||||
)
|
Move.contest_effect = relation(ContestEffect,
|
||||||
Move.contest_effect = relation(ContestEffect, backref='moves')
|
backref='moves')
|
||||||
Move.contest_combo_next = association_proxy('contest_combo_first', 'second')
|
Move.contest_combo_next = association_proxy('contest_combo_first', 'second')
|
||||||
Move.contest_combo_prev = association_proxy('contest_combo_second', 'first')
|
Move.contest_combo_prev = association_proxy('contest_combo_second', 'first')
|
||||||
Move.contest_type = relation(ContestType, backref='moves')
|
Move.contest_type = relation(ContestType,
|
||||||
Move.damage_class = relation(MoveDamageClass, backref='moves')
|
backref='moves')
|
||||||
|
Move.damage_class = relation(MoveDamageClass,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='moves')
|
||||||
Move.flags = association_proxy('move_flags', 'flag')
|
Move.flags = association_proxy('move_flags', 'flag')
|
||||||
Move.flavor_text = relation(MoveFlavorText, order_by=MoveFlavorText.version_group_id, backref='move')
|
Move.flavor_text = relation(MoveFlavorText,
|
||||||
Move.generation = relation(Generation, backref='moves')
|
order_by=MoveFlavorText.version_group_id, backref='move')
|
||||||
Move.machines = relation(Machine, backref='move')
|
Move.generation = relation(Generation,
|
||||||
Move.meta = relation(MoveMeta, uselist=False, backref='move')
|
innerjoin=True,
|
||||||
|
backref='moves')
|
||||||
|
Move.machines = relation(Machine,
|
||||||
|
backref='move')
|
||||||
|
Move.meta = relation(MoveMeta,
|
||||||
|
uselist=False, innerjoin=True,
|
||||||
|
backref='move')
|
||||||
Move.meta_stat_changes = relation(MoveMetaStatChange)
|
Move.meta_stat_changes = relation(MoveMetaStatChange)
|
||||||
Move.move_effect = relation(MoveEffect, backref='moves')
|
Move.move_effect = relation(MoveEffect,
|
||||||
Move.move_flags = relation(MoveFlag, backref='move')
|
innerjoin=True,
|
||||||
Move.super_contest_effect = relation(SuperContestEffect, backref='moves')
|
backref='moves')
|
||||||
|
Move.move_flags = relation(MoveFlag,
|
||||||
|
backref='move')
|
||||||
|
Move.super_contest_effect = relation(SuperContestEffect,
|
||||||
|
backref='moves')
|
||||||
Move.super_contest_combo_next = association_proxy('super_contest_combo_first', 'second')
|
Move.super_contest_combo_next = association_proxy('super_contest_combo_first', 'second')
|
||||||
Move.super_contest_combo_prev = association_proxy('super_contest_combo_second', 'first')
|
Move.super_contest_combo_prev = association_proxy('super_contest_combo_second', 'first')
|
||||||
Move.target = relation(MoveTarget, backref='moves')
|
Move.target = relation(MoveTarget,
|
||||||
Move.type = relation(Type, backref='moves')
|
innerjoin=True,
|
||||||
|
backref='moves')
|
||||||
|
Move.type = relation(Type,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='moves')
|
||||||
|
|
||||||
Move.effect = markdown.MoveEffectProperty('effect')
|
Move.effect = markdown.MoveEffectProperty('effect')
|
||||||
Move.effect_map = markdown.MoveEffectPropertyMap('effect_map')
|
Move.effect_map = markdown.MoveEffectPropertyMap('effect_map')
|
||||||
Move.short_effect = markdown.MoveEffectProperty('short_effect')
|
Move.short_effect = markdown.MoveEffectProperty('short_effect')
|
||||||
Move.short_effect_map = markdown.MoveEffectPropertyMap('short_effect_map')
|
Move.short_effect_map = markdown.MoveEffectPropertyMap('short_effect_map')
|
||||||
|
|
||||||
MoveChangelog.changed_in = relation(VersionGroup, backref='move_changelog')
|
MoveChangelog.changed_in = relation(VersionGroup,
|
||||||
MoveChangelog.move_effect = relation(MoveEffect, backref='move_changelog')
|
innerjoin=True, lazy='joined',
|
||||||
MoveChangelog.type = relation(Type, backref='move_changelog')
|
backref='move_changelog')
|
||||||
|
MoveChangelog.move_effect = relation(MoveEffect,
|
||||||
|
backref='move_changelog')
|
||||||
|
MoveChangelog.type = relation(Type,
|
||||||
|
backref='move_changelog')
|
||||||
|
|
||||||
MoveChangelog.effect = markdown.MoveEffectProperty('effect')
|
MoveChangelog.effect = markdown.MoveEffectProperty('effect')
|
||||||
MoveChangelog.effect_map = markdown.MoveEffectPropertyMap('effect_map')
|
MoveChangelog.effect_map = markdown.MoveEffectPropertyMap('effect_map')
|
||||||
|
@ -1798,47 +1895,78 @@ MoveEffect.category_map = relation(MoveEffectCategoryMap)
|
||||||
MoveEffect.categories = association_proxy('category_map', 'category')
|
MoveEffect.categories = association_proxy('category_map', 'category')
|
||||||
MoveEffect.changelog = relation(MoveEffectChangelog,
|
MoveEffect.changelog = relation(MoveEffectChangelog,
|
||||||
order_by=MoveEffectChangelog.changed_in_version_group_id.desc(),
|
order_by=MoveEffectChangelog.changed_in_version_group_id.desc(),
|
||||||
backref='move_effect',
|
backref='move_effect')
|
||||||
)
|
|
||||||
MoveEffectCategoryMap.category = relation(MoveEffectCategory)
|
MoveEffectCategoryMap.category = relation(MoveEffectCategory)
|
||||||
|
|
||||||
MoveEffectChangelog.changed_in = relation(VersionGroup, backref='move_effect_changelog')
|
MoveEffectChangelog.changed_in = relation(VersionGroup,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='move_effect_changelog')
|
||||||
|
|
||||||
MoveFlag.flag = relation(MoveFlagType)
|
MoveFlag.flag = relation(MoveFlagType, innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
MoveFlavorText.version_group = relation(VersionGroup)
|
MoveFlavorText.version_group = relation(VersionGroup,
|
||||||
MoveFlavorText.language = relation(Language)
|
innerjoin=True, lazy='joined')
|
||||||
|
MoveFlavorText.language = relation(Language,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
MoveMeta.category = relation(MoveMetaCategory, backref='move_meta')
|
MoveMeta.category = relation(MoveMetaCategory,
|
||||||
MoveMeta.ailment = relation(MoveMetaAilment, backref='move_meta')
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='move_meta')
|
||||||
|
MoveMeta.ailment = relation(MoveMetaAilment,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='move_meta')
|
||||||
|
|
||||||
MoveMetaStatChange.stat = relation(Stat, backref='move_meta_stat_changes')
|
MoveMetaStatChange.stat = relation(Stat,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='move_meta_stat_changes')
|
||||||
|
|
||||||
Nature.decreased_stat = relation(Stat, primaryjoin=Nature.decreased_stat_id==Stat.id,
|
|
||||||
|
Nature.decreased_stat = relation(Stat,
|
||||||
|
primaryjoin=Nature.decreased_stat_id==Stat.id,
|
||||||
|
innerjoin=True,
|
||||||
backref='decreasing_natures')
|
backref='decreasing_natures')
|
||||||
Nature.increased_stat = relation(Stat, primaryjoin=Nature.increased_stat_id==Stat.id,
|
Nature.increased_stat = relation(Stat,
|
||||||
|
primaryjoin=Nature.increased_stat_id==Stat.id,
|
||||||
|
innerjoin=True,
|
||||||
backref='increasing_natures')
|
backref='increasing_natures')
|
||||||
Nature.hates_flavor = relation(ContestType, primaryjoin=Nature.hates_flavor_id==ContestType.id,
|
Nature.hates_flavor = relation(ContestType,
|
||||||
|
primaryjoin=Nature.hates_flavor_id==ContestType.id,
|
||||||
|
innerjoin=True,
|
||||||
backref='hating_natures')
|
backref='hating_natures')
|
||||||
Nature.likes_flavor = relation(ContestType, primaryjoin=Nature.likes_flavor_id==ContestType.id,
|
Nature.likes_flavor = relation(ContestType,
|
||||||
|
primaryjoin=Nature.likes_flavor_id==ContestType.id,
|
||||||
|
innerjoin=True,
|
||||||
backref='liking_natures')
|
backref='liking_natures')
|
||||||
Nature.battle_style_preferences = relation(NatureBattleStylePreference,
|
Nature.battle_style_preferences = relation(NatureBattleStylePreference,
|
||||||
order_by=NatureBattleStylePreference.move_battle_style_id,
|
order_by=NatureBattleStylePreference.move_battle_style_id.asc(),
|
||||||
backref='nature')
|
backref='nature')
|
||||||
Nature.pokeathlon_effects = relation(NaturePokeathlonStat, order_by=NaturePokeathlonStat.pokeathlon_stat_id)
|
Nature.pokeathlon_effects = relation(NaturePokeathlonStat,
|
||||||
|
order_by=NaturePokeathlonStat.pokeathlon_stat_id.asc())
|
||||||
|
|
||||||
NatureBattleStylePreference.battle_style = relation(MoveBattleStyle, backref='nature_preferences')
|
NatureBattleStylePreference.battle_style = relation(MoveBattleStyle,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='nature_preferences')
|
||||||
|
|
||||||
NaturePokeathlonStat.pokeathlon_stat = relation(PokeathlonStat, backref='nature_effects')
|
NaturePokeathlonStat.pokeathlon_stat = relation(PokeathlonStat,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='nature_effects')
|
||||||
|
|
||||||
|
|
||||||
|
Pokedex.region = relation(Region,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='pokedexes')
|
||||||
|
Pokedex.version_groups = relation(VersionGroup,
|
||||||
|
innerjoin=True,
|
||||||
|
order_by=VersionGroup.id.asc(),
|
||||||
|
backref='pokedex')
|
||||||
|
|
||||||
Pokedex.region = relation(Region, backref='pokedexes')
|
|
||||||
Pokedex.version_groups = relation(VersionGroup, order_by=VersionGroup.id, backref='pokedex')
|
|
||||||
|
|
||||||
Pokemon.all_abilities = relation(Ability,
|
Pokemon.all_abilities = relation(Ability,
|
||||||
secondary=PokemonAbility.__table__,
|
secondary=PokemonAbility.__table__,
|
||||||
order_by=PokemonAbility.slot,
|
order_by=PokemonAbility.slot.asc(),
|
||||||
|
innerjoin=True,
|
||||||
backref=backref('all_pokemon',
|
backref=backref('all_pokemon',
|
||||||
order_by=Pokemon.order,
|
order_by=Pokemon.order.asc(),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
Pokemon.abilities = relation(Ability,
|
Pokemon.abilities = relation(Ability,
|
||||||
|
@ -1847,9 +1975,10 @@ Pokemon.abilities = relation(Ability,
|
||||||
Pokemon.id == PokemonAbility.pokemon_id,
|
Pokemon.id == PokemonAbility.pokemon_id,
|
||||||
PokemonAbility.is_dream == False,
|
PokemonAbility.is_dream == False,
|
||||||
),
|
),
|
||||||
order_by=PokemonAbility.slot,
|
innerjoin=True,
|
||||||
|
order_by=PokemonAbility.slot.asc(),
|
||||||
backref=backref('pokemon',
|
backref=backref('pokemon',
|
||||||
order_by=Pokemon.order,
|
order_by=Pokemon.order.asc(),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
Pokemon.dream_ability = relation(Ability,
|
Pokemon.dream_ability = relation(Ability,
|
||||||
|
@ -1863,137 +1992,194 @@ Pokemon.dream_ability = relation(Ability,
|
||||||
order_by=Pokemon.order,
|
order_by=Pokemon.order,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
Pokemon.pokemon_color = relation(PokemonColor, backref='pokemon')
|
Pokemon.pokemon_color = relation(PokemonColor,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='pokemon')
|
||||||
Pokemon.color = association_proxy('pokemon_color', 'name')
|
Pokemon.color = association_proxy('pokemon_color', 'name')
|
||||||
Pokemon.dex_numbers = relation(PokemonDexNumber, order_by=PokemonDexNumber.pokedex_id.asc(), backref='pokemon')
|
Pokemon.dex_numbers = relation(PokemonDexNumber,
|
||||||
Pokemon.egg_groups = relation(EggGroup, secondary=PokemonEggGroup.__table__,
|
innerjoin=True,
|
||||||
order_by=PokemonEggGroup.egg_group_id,
|
order_by=PokemonDexNumber.pokedex_id.asc(),
|
||||||
backref=backref('pokemon', order_by=Pokemon.order))
|
backref='pokemon')
|
||||||
Pokemon.evolution_chain = relation(EvolutionChain, backref=backref('pokemon', order_by=Pokemon.order))
|
Pokemon.egg_groups = relation(EggGroup,
|
||||||
|
secondary=PokemonEggGroup.__table__,
|
||||||
|
innerjoin=True,
|
||||||
|
order_by=PokemonEggGroup.egg_group_id.asc(),
|
||||||
|
backref=backref('pokemon', order_by=Pokemon.order.asc()))
|
||||||
|
Pokemon.evolution_chain = relation(EvolutionChain,
|
||||||
|
innerjoin=True,
|
||||||
|
backref=backref('pokemon', order_by=Pokemon.order.asc()))
|
||||||
Pokemon.child_pokemon = relation(Pokemon,
|
Pokemon.child_pokemon = relation(Pokemon,
|
||||||
primaryjoin=Pokemon.id==PokemonEvolution.from_pokemon_id,
|
primaryjoin=Pokemon.id==PokemonEvolution.from_pokemon_id,
|
||||||
secondary=PokemonEvolution.__table__,
|
secondary=PokemonEvolution.__table__,
|
||||||
secondaryjoin=PokemonEvolution.to_pokemon_id==Pokemon.id,
|
secondaryjoin=PokemonEvolution.to_pokemon_id==Pokemon.id,
|
||||||
backref=backref('parent_pokemon', uselist=False),
|
backref=backref('parent_pokemon', uselist=False))
|
||||||
)
|
Pokemon.flavor_text = relation(PokemonFlavorText,
|
||||||
Pokemon.flavor_text = relation(PokemonFlavorText, order_by=PokemonFlavorText.version_id.asc(), backref='pokemon')
|
order_by=PokemonFlavorText.version_id.asc(),
|
||||||
Pokemon.forms = relation(PokemonForm, primaryjoin=Pokemon.id==PokemonForm.form_base_pokemon_id,
|
backref='pokemon')
|
||||||
|
Pokemon.forms = relation(PokemonForm,
|
||||||
|
primaryjoin=Pokemon.id==PokemonForm.form_base_pokemon_id,
|
||||||
order_by=(PokemonForm.order.asc(), PokemonForm.identifier.asc()))
|
order_by=(PokemonForm.order.asc(), PokemonForm.identifier.asc()))
|
||||||
Pokemon.default_form = relation(PokemonForm,
|
Pokemon.default_form = relation(PokemonForm,
|
||||||
primaryjoin=and_(Pokemon.id==PokemonForm.form_base_pokemon_id, PokemonForm.is_default==True),
|
primaryjoin=and_(
|
||||||
uselist=False,
|
Pokemon.id==PokemonForm.form_base_pokemon_id,
|
||||||
)
|
PokemonForm.is_default==True),
|
||||||
Pokemon.pokemon_habitat = relation(PokemonHabitat, backref='pokemon')
|
uselist=False)
|
||||||
|
Pokemon.pokemon_habitat = relation(PokemonHabitat,
|
||||||
|
backref='pokemon')
|
||||||
Pokemon.habitat = association_proxy('pokemon_habitat', 'name')
|
Pokemon.habitat = association_proxy('pokemon_habitat', 'name')
|
||||||
Pokemon.items = relation(PokemonItem, backref='pokemon')
|
Pokemon.items = relation(PokemonItem,
|
||||||
Pokemon.generation = relation(Generation, backref='pokemon')
|
backref='pokemon')
|
||||||
Pokemon.shape = relation(PokemonShape, backref='pokemon')
|
Pokemon.generation = relation(Generation,
|
||||||
Pokemon.stats = relation(PokemonStat, backref='pokemon', order_by=PokemonStat.stat_id.asc())
|
innerjoin=True,
|
||||||
|
backref='pokemon')
|
||||||
|
Pokemon.shape = relation(PokemonShape,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='pokemon')
|
||||||
|
Pokemon.stats = relation(PokemonStat,
|
||||||
|
innerjoin=True,
|
||||||
|
order_by=PokemonStat.stat_id.asc(),
|
||||||
|
backref='pokemon')
|
||||||
Pokemon.types = relation(Type,
|
Pokemon.types = relation(Type,
|
||||||
secondary=PokemonType.__table__,
|
secondary=PokemonType.__table__,
|
||||||
|
innerjoin=True,
|
||||||
order_by=PokemonType.slot.asc(),
|
order_by=PokemonType.slot.asc(),
|
||||||
backref=backref('pokemon', order_by=Pokemon.order),
|
backref=backref('pokemon', order_by=Pokemon.order))
|
||||||
)
|
|
||||||
|
|
||||||
PokemonDexNumber.pokedex = relation(Pokedex)
|
PokemonDexNumber.pokedex = relation(Pokedex,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
PokemonEvolution.from_pokemon = relation(Pokemon,
|
PokemonEvolution.from_pokemon = relation(Pokemon,
|
||||||
primaryjoin=PokemonEvolution.from_pokemon_id==Pokemon.id,
|
primaryjoin=PokemonEvolution.from_pokemon_id==Pokemon.id,
|
||||||
backref='child_evolutions',
|
innerjoin=True,
|
||||||
)
|
backref='child_evolutions')
|
||||||
PokemonEvolution.to_pokemon = relation(Pokemon,
|
PokemonEvolution.to_pokemon = relation(Pokemon,
|
||||||
primaryjoin=PokemonEvolution.to_pokemon_id==Pokemon.id,
|
primaryjoin=PokemonEvolution.to_pokemon_id==Pokemon.id,
|
||||||
backref=backref('parent_evolution', uselist=False),
|
innerjoin=True,
|
||||||
)
|
backref=backref('parent_evolution', uselist=False))
|
||||||
PokemonEvolution.child_evolutions = relation(PokemonEvolution,
|
PokemonEvolution.child_evolutions = relation(PokemonEvolution,
|
||||||
primaryjoin=PokemonEvolution.from_pokemon_id==PokemonEvolution.to_pokemon_id,
|
primaryjoin=PokemonEvolution.from_pokemon_id==PokemonEvolution.to_pokemon_id,
|
||||||
foreign_keys=[PokemonEvolution.to_pokemon_id],
|
foreign_keys=[PokemonEvolution.to_pokemon_id],
|
||||||
backref=backref('parent_evolution',
|
backref=backref('parent_evolution',
|
||||||
remote_side=[PokemonEvolution.from_pokemon_id],
|
remote_side=[PokemonEvolution.from_pokemon_id],
|
||||||
uselist=False,
|
uselist=False))
|
||||||
),
|
PokemonEvolution.trigger = relation(EvolutionTrigger,
|
||||||
)
|
innerjoin=True, lazy='joined',
|
||||||
PokemonEvolution.trigger = relation(EvolutionTrigger, backref='evolutions')
|
backref='evolutions')
|
||||||
PokemonEvolution.trigger_item = relation(Item,
|
PokemonEvolution.trigger_item = relation(Item,
|
||||||
primaryjoin=PokemonEvolution.trigger_item_id==Item.id,
|
primaryjoin=PokemonEvolution.trigger_item_id==Item.id,
|
||||||
backref='triggered_evolutions',
|
backref='triggered_evolutions')
|
||||||
)
|
|
||||||
PokemonEvolution.held_item = relation(Item,
|
PokemonEvolution.held_item = relation(Item,
|
||||||
primaryjoin=PokemonEvolution.held_item_id==Item.id,
|
primaryjoin=PokemonEvolution.held_item_id==Item.id,
|
||||||
backref='required_for_evolutions',
|
backref='required_for_evolutions')
|
||||||
)
|
PokemonEvolution.location = relation(Location,
|
||||||
PokemonEvolution.location = relation(Location, backref='triggered_evolutions')
|
backref='triggered_evolutions')
|
||||||
PokemonEvolution.known_move = relation(Move, backref='triggered_evolutions')
|
PokemonEvolution.known_move = relation(Move,
|
||||||
|
backref='triggered_evolutions')
|
||||||
PokemonEvolution.party_pokemon = relation(Pokemon,
|
PokemonEvolution.party_pokemon = relation(Pokemon,
|
||||||
primaryjoin=PokemonEvolution.party_pokemon_id==Pokemon.id,
|
primaryjoin=PokemonEvolution.party_pokemon_id==Pokemon.id,
|
||||||
backref='triggered_evolutions',
|
backref='triggered_evolutions')
|
||||||
)
|
|
||||||
PokemonEvolution.trade_pokemon = relation(Pokemon,
|
PokemonEvolution.trade_pokemon = relation(Pokemon,
|
||||||
primaryjoin=PokemonEvolution.trade_pokemon_id==Pokemon.id,
|
primaryjoin=PokemonEvolution.trade_pokemon_id==Pokemon.id)
|
||||||
)
|
|
||||||
|
|
||||||
PokemonFlavorText.version = relation(Version)
|
PokemonFlavorText.version = relation(Version, innerjoin=True, lazy='joined')
|
||||||
PokemonFlavorText.language = relation(Language)
|
PokemonFlavorText.language = relation(Language, innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
PokemonForm.form_base_pokemon = relation(Pokemon, primaryjoin=PokemonForm.form_base_pokemon_id==Pokemon.id)
|
PokemonForm.form_base_pokemon = relation(Pokemon,
|
||||||
PokemonForm.unique_pokemon = relation(Pokemon, backref=backref('unique_form', uselist=False),
|
primaryjoin=PokemonForm.form_base_pokemon_id==Pokemon.id,
|
||||||
primaryjoin=PokemonForm.unique_pokemon_id==Pokemon.id)
|
innerjoin=True)
|
||||||
PokemonForm.version_group = relation(VersionGroup)
|
PokemonForm.unique_pokemon = relation(Pokemon,
|
||||||
|
primaryjoin=PokemonForm.unique_pokemon_id==Pokemon.id,
|
||||||
|
backref=backref('unique_form', uselist=False))
|
||||||
|
PokemonForm.version_group = relation(VersionGroup,
|
||||||
|
innerjoin=True)
|
||||||
PokemonForm.form_group = association_proxy('form_base_pokemon', 'form_group')
|
PokemonForm.form_group = association_proxy('form_base_pokemon', 'form_group')
|
||||||
PokemonForm.pokeathlon_stats = relation(PokemonFormPokeathlonStat,
|
PokemonForm.pokeathlon_stats = relation(PokemonFormPokeathlonStat,
|
||||||
order_by=PokemonFormPokeathlonStat.pokeathlon_stat_id,
|
order_by=PokemonFormPokeathlonStat.pokeathlon_stat_id,
|
||||||
backref='pokemon_form')
|
backref='pokemon_form')
|
||||||
|
|
||||||
PokemonFormGroup.pokemon = relation(Pokemon, backref=backref('form_group',
|
PokemonFormGroup.pokemon = relation(Pokemon,
|
||||||
uselist=False))
|
innerjoin=True,
|
||||||
|
backref=backref('form_group', uselist=False))
|
||||||
|
|
||||||
PokemonFormPokeathlonStat.pokeathlon_stat = relation(PokeathlonStat)
|
PokemonFormPokeathlonStat.pokeathlon_stat = relation(PokeathlonStat,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
PokemonItem.item = relation(Item, backref='pokemon')
|
PokemonItem.item = relation(Item,
|
||||||
PokemonItem.version = relation(Version)
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='pokemon')
|
||||||
|
PokemonItem.version = relation(Version,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
PokemonMove.pokemon = relation(Pokemon, backref='pokemon_moves')
|
PokemonMove.pokemon = relation(Pokemon,
|
||||||
PokemonMove.version_group = relation(VersionGroup)
|
innerjoin=True, lazy='joined',
|
||||||
PokemonMove.machine = relation(Machine, backref='pokemon_moves',
|
backref='pokemon_moves')
|
||||||
primaryjoin=and_(Machine.version_group_id==PokemonMove.version_group_id,
|
PokemonMove.version_group = relation(VersionGroup,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
PokemonMove.machine = relation(Machine,
|
||||||
|
primaryjoin=and_(
|
||||||
|
Machine.version_group_id==PokemonMove.version_group_id,
|
||||||
Machine.move_id==PokemonMove.move_id),
|
Machine.move_id==PokemonMove.move_id),
|
||||||
foreign_keys=[Machine.version_group_id, Machine.move_id],
|
foreign_keys=[Machine.version_group_id, Machine.move_id],
|
||||||
uselist=False)
|
uselist=False,
|
||||||
PokemonMove.move = relation(Move, backref='pokemon_moves')
|
backref='pokemon_moves')
|
||||||
PokemonMove.method = relation(PokemonMoveMethod)
|
PokemonMove.move = relation(Move,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='pokemon_moves')
|
||||||
|
PokemonMove.method = relation(PokemonMoveMethod,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
|
PokemonStat.stat = relation(Stat,
|
||||||
|
innerjoin=True, lazy='joined')
|
||||||
|
|
||||||
PokemonStat.stat = relation(Stat)
|
|
||||||
|
|
||||||
# This is technically a has-many; Generation.main_region_id -> Region.id
|
|
||||||
Region.generation = relation(Generation, uselist=False)
|
Region.generation = relation(Generation, uselist=False)
|
||||||
Region.version_group_regions = relation(VersionGroupRegion, backref='region',
|
Region.version_group_regions = relation(VersionGroupRegion,
|
||||||
order_by='VersionGroupRegion.version_group_id')
|
order_by=VersionGroupRegion.version_group_id.asc(),
|
||||||
|
backref='region')
|
||||||
Region.version_groups = association_proxy('version_group_regions', 'version_group')
|
Region.version_groups = association_proxy('version_group_regions', 'version_group')
|
||||||
|
|
||||||
Stat.damage_class = relation(MoveDamageClass, backref='stats')
|
|
||||||
|
|
||||||
StatHint.stat = relation(Stat, backref='hints')
|
Stat.damage_class = relation(MoveDamageClass,
|
||||||
|
backref='stats')
|
||||||
|
|
||||||
SuperContestCombo.first = relation(Move, primaryjoin=SuperContestCombo.first_move_id==Move.id,
|
StatHint.stat = relation(Stat,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='hints')
|
||||||
|
|
||||||
|
|
||||||
|
SuperContestCombo.first = relation(Move,
|
||||||
|
primaryjoin=SuperContestCombo.first_move_id==Move.id,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
backref='super_contest_combo_first')
|
backref='super_contest_combo_first')
|
||||||
SuperContestCombo.second = relation(Move, primaryjoin=SuperContestCombo.second_move_id==Move.id,
|
SuperContestCombo.second = relation(Move,
|
||||||
|
primaryjoin=SuperContestCombo.second_move_id==Move.id,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
backref='super_contest_combo_second')
|
backref='super_contest_combo_second')
|
||||||
|
|
||||||
Type.damage_efficacies = relation(TypeEfficacy,
|
|
||||||
primaryjoin=Type.id
|
|
||||||
==TypeEfficacy.damage_type_id,
|
|
||||||
backref='damage_type')
|
|
||||||
Type.target_efficacies = relation(TypeEfficacy,
|
|
||||||
primaryjoin=Type.id
|
|
||||||
==TypeEfficacy.target_type_id,
|
|
||||||
backref='target_type')
|
|
||||||
|
|
||||||
Type.generation = relation(Generation, backref='types')
|
Type.damage_efficacies = relation(TypeEfficacy,
|
||||||
Type.damage_class = relation(MoveDamageClass, backref='types')
|
primaryjoin=Type.id==TypeEfficacy.damage_type_id,
|
||||||
|
backref=backref('damage_type', innerjoin=True, lazy='joined'))
|
||||||
|
Type.target_efficacies = relation(TypeEfficacy,
|
||||||
|
primaryjoin=Type.id==TypeEfficacy.target_type_id,
|
||||||
|
backref=backref('target_type', innerjoin=True, lazy='joined'))
|
||||||
|
|
||||||
|
Type.generation = relation(Generation,
|
||||||
|
innerjoin=True,
|
||||||
|
backref='types')
|
||||||
|
Type.damage_class = relation(MoveDamageClass,
|
||||||
|
backref='types')
|
||||||
|
|
||||||
|
|
||||||
Version.generation = association_proxy('version_group', 'generation')
|
Version.generation = association_proxy('version_group', 'generation')
|
||||||
|
|
||||||
VersionGroup.versions = relation(Version, order_by=Version.id, backref='version_group')
|
VersionGroup.versions = relation(Version,
|
||||||
VersionGroup.generation = relation(Generation, backref='version_groups')
|
innerjoin=True,
|
||||||
VersionGroup.version_group_regions = relation(VersionGroupRegion, backref='version_group')
|
order_by=Version.id,
|
||||||
|
backref=backref('version_group', lazy='joined'))
|
||||||
|
VersionGroup.generation = relation(Generation,
|
||||||
|
innerjoin=True, lazy='joined',
|
||||||
|
backref='version_groups')
|
||||||
|
VersionGroup.version_group_regions = relation(VersionGroupRegion,
|
||||||
|
backref='version_group')
|
||||||
VersionGroup.regions = association_proxy('version_group_regions', 'region')
|
VersionGroup.regions = association_proxy('version_group_regions', 'region')
|
||||||
|
|
Loading…
Reference in a new issue