Added a truckload of innerjoins and joinedloads.

Also reformatted the relationship definitions.  Now less of a clusterfuck.
This commit is contained in:
Eevee 2011-04-03 01:26:55 -07:00
parent d90db39d43
commit c519a4c824

View file

@ -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,
backref='contest_combo_first')
ContestCombo.second = relation(Move, primaryjoin=ContestCombo.second_move_id==Move.id,
backref='contest_combo_second')
Encounter.location_area = relation(LocationArea, backref='encounters') ContestCombo.first = relation(Move,
Encounter.pokemon = relation(Pokemon, backref='encounters') primaryjoin=ContestCombo.first_move_id==Move.id,
Encounter.version = relation(Version, backref='encounters') innerjoin=True, lazy='joined',
Encounter.slot = relation(EncounterSlot, backref='encounters') backref='contest_combo_first')
ContestCombo.second = relation(Move,
primaryjoin=ContestCombo.second_move_id==Move.id,
innerjoin=True, lazy='joined',
backref='contest_combo_second')
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,
backref='encounter_map') innerjoin=True, lazy='joined',
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,
backref='decreasing_natures') Nature.decreased_stat = relation(Stat,
Nature.increased_stat = relation(Stat, primaryjoin=Nature.increased_stat_id==Stat.id, primaryjoin=Nature.decreased_stat_id==Stat.id,
backref='increasing_natures') innerjoin=True,
Nature.hates_flavor = relation(ContestType, primaryjoin=Nature.hates_flavor_id==ContestType.id, backref='decreasing_natures')
backref='hating_natures') Nature.increased_stat = relation(Stat,
Nature.likes_flavor = relation(ContestType, primaryjoin=Nature.likes_flavor_id==ContestType.id, primaryjoin=Nature.increased_stat_id==Stat.id,
backref='liking_natures') innerjoin=True,
backref='increasing_natures')
Nature.hates_flavor = relation(ContestType,
primaryjoin=Nature.hates_flavor_id==ContestType.id,
innerjoin=True,
backref='hating_natures')
Nature.likes_flavor = relation(ContestType,
primaryjoin=Nature.likes_flavor_id==ContestType.id,
innerjoin=True,
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')
order_by=(PokemonForm.order.asc(), PokemonForm.identifier.asc())) Pokemon.forms = relation(PokemonForm,
primaryjoin=Pokemon.id==PokemonForm.form_base_pokemon_id,
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,
Machine.move_id==PokemonMove.move_id), innerjoin=True, lazy='joined')
foreign_keys=[Machine.version_group_id, Machine.move_id], PokemonMove.machine = relation(Machine,
uselist=False) primaryjoin=and_(
PokemonMove.move = relation(Move, backref='pokemon_moves') Machine.version_group_id==PokemonMove.version_group_id,
PokemonMove.method = relation(PokemonMoveMethod) Machine.move_id==PokemonMove.move_id),
foreign_keys=[Machine.version_group_id, Machine.move_id],
uselist=False,
backref='pokemon_moves')
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')
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')
SuperContestCombo.second = relation(Move,
primaryjoin=SuperContestCombo.second_move_id==Move.id,
innerjoin=True, lazy='joined',
backref='super_contest_combo_second')
SuperContestCombo.first = relation(Move, primaryjoin=SuperContestCombo.first_move_id==Move.id,
backref='super_contest_combo_first')
SuperContestCombo.second = relation(Move, primaryjoin=SuperContestCombo.second_move_id==Move.id,
backref='super_contest_combo_second')
Type.damage_efficacies = relation(TypeEfficacy, Type.damage_efficacies = relation(TypeEfficacy,
primaryjoin=Type.id primaryjoin=Type.id==TypeEfficacy.damage_type_id,
==TypeEfficacy.damage_type_id, backref=backref('damage_type', innerjoin=True, lazy='joined'))
backref='damage_type')
Type.target_efficacies = relation(TypeEfficacy, Type.target_efficacies = relation(TypeEfficacy,
primaryjoin=Type.id primaryjoin=Type.id==TypeEfficacy.target_type_id,
==TypeEfficacy.target_type_id, backref=backref('target_type', innerjoin=True, lazy='joined'))
backref='target_type')
Type.generation = relation(Generation,
innerjoin=True,
backref='types')
Type.damage_class = relation(MoveDamageClass,
backref='types')
Type.generation = relation(Generation, 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')