Найти - Пользователи
Полная версия: sqlalchemy связь таблиц
Начало » Базы данных » sqlalchemy связь таблиц
1
PROeXT
Всем привет. Почитал мануал, попробовал, ничего не получается…
Есть две таблицы.
users (
id Integer, primary-key, auto-inc
fio string 150
region_id integer
)

regions(
id integer primary-key, auto-inc,
val string 100
)
Как я не пытался связать их между собой - все не выходит :( HELP
PROeXT
Все, спасибо. Сам разобрался.
BION
PROeXT
Ну раз уж разобрался, так запости, так сказать для потомков :)
PROeXT
BION
PROeXT
Ну раз уж разобрался, так запости, так сказать для потомков :)
Ну что ж. Для потомков - это святое. Выкладываю пример полного листинга:

# -*-coding: utf-8; show-trailing-whitespace: t -*-

import sqlite3
from sqlalchemy import Table, ForeignKey, Unicode, Integer, create_engine, MetaData, Column
from sqlalchemy.orm import mapper, sessionmaker, scoped_session, relation

engine = create_engine("sqlite:///memory")
Session = scoped_session(sessionmaker(autoflush=True, transactional=True, bind=engine))
session = Session()
metadata = MetaData(bind=engine)



tbl_regions = Table("regions", metadata,
Column("id", Integer, primary_key=True),
Column("reg_name", Unicode(100)))

tbl_person = Table("persons", metadata,
Column("id", Integer, primary_key=True),
Column("fio", Unicode(150)),
Column("region_id", Integer, ForeignKey("regions.id")))

class Person(object):
def __init__(self, fio=u""):
self.fio = fio

def repr(self):
return "<Person(id:{%d}, fio:{%s})>" % (self.id, self.fio)

class Region(object):
def __init__(self, reg_name=u""):
self.reg_name = reg_name

def repr(self):
return "<Region(id:{%d}, reg_name:{%s})>" % (self.id, self.reg_name)

mapper(Region, tbl_regions)
mapper(Person, tbl_person,
properties={"regions": relation(Region, uselist=True)})


############################################################################
# #
# Testing block #
# #
############################################################################

import unittest

class TestApp(unittest.TestCase):
def setUp(self):
metadata.create_all()
def tearDown(self):
metadata.drop_all()

def test_main(self):
person = Person(u"Test fio")
person.regions.append(Region(u"This is the test region"))
session.save(person)
session.commit()
self.assertEqual(person.regions[0].reg_name, u"This is the test region")

if __name__ == "__main__":
unittest.main()
Ferroman
Был бы рейтинг - поставил бы + за юнитесты.
PROeXT
Ferroman
Был бы рейтинг - поставил бы + за юнитесты.
:)
m.meehalkoff
PROeXT
Ну что ж. Для потомков - это святое. Выкладываю пример полного листинга:
Хочется прокомментировать этот код :)

PROeXT
import sqlite3
Для чего импортирован этот модуль? Вы его где то используете в программе?

PROeXT
engine = create_engine("sqlite:///memory")
В результате выполнения этой строки получается файл ‘memory’, а Вы видимо хотели использовать базу в оперативной памяти, не создавая файл. Следует исправить на (“sqlite:///:memory:”)

PROeXT
Session = scoped_session(sessionmaker(autoflush=True, transactional=True, bind=engine))
autoflush = True по умолчанию
transactional=True Нет такого параметра и использование его приводит к ошибке.

PROeXT
def test_main(self):
#…
session.save(person)
К сожалению нет такого метода и в итоге ошибка.

Вывод:
Код не работает. Хотя с вопросом связывания таблиц Вы разобрались))
PooH
m.meehalkoff
Вывод:
Код не работает. Хотя с вопросом связывания таблиц Вы разобрались))
А вы не подумали что версии алхимии у вас и топикстартера могут отличаться?
This is a "lo-fi" version of our main content. To view the full version with more information, formatting and images, please click here.
Powered by DjangoBB