Форум программистов, компьютерный форум, киберфорум
Python: Web
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
49 / 37 / 14
Регистрация: 05.02.2010
Сообщений: 249

Взаимное расположение таблиц и связь manytomany

20.04.2015, 19:00. Показов 1476. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Итак есть необходимость в админке реализовать возможность добавление многие ко многим.
База у меня уже была готовая (Постгре)
Модели:
Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
class DimSensor(models.Model):
    sensid = models.CharField(primary_key=True, max_length=64)
    sensor_type_sid = models.ForeignKey(DirSensorType, db_column = 'sensor_type_sid')
    link_id = models.ManyToManyField(LinkRoomBedLink, through='LinkSensorRoomLink', through_fields=('sensid','room_bed_link_sid'), blank=True, null=True)
    def __unicode__(self):
        return self.sensid
    class Meta:
        managed = False
        db_table = 'dim_sensor'
        verbose_name_plural = "Список датчиков"   
 
class LinkRoomBedLink(models.Model):
    room_bed_link_sid = models.IntegerField(primary_key=True)
    lpu_id = models.ForeignKey(DirLpu, db_column = 'lpu_id', blank=True, null=True)
    dep_sid = models.ForeignKey(DirDep, db_column = 'dep_sid', blank=True, null=True)
    sensors_id = models.ManyToManyField(DimSensor, through='LinkSensorRoomLink', through_fields=('room_bed_link_sid', 'sensid'), blank=True, null=True)
    room_num = models.CharField(max_length=64, blank=True, null=True)
    bed_num = models.CharField(max_length=64, blank=True, null=True)
    sysdate = models.DateTimeField(blank=True, null=True)
    def __unicode__(self):
        return self.bed_num
    class Meta:
        managed = False
        db_table = 'link_room_bed_link'
        verbose_name_plural = "Палаты и койки"
 
class LinkSensorRoomLink(models.Model):
    sensor_room_link_sid = models.IntegerField(primary_key=True)
    room_bed_link_sid = models.ForeignKey(LinkRoomBedLink, db_column = 'room_bed_link_sid')
    sensid = models.ForeignKey(DimSensor, db_column = 'sensid')
    sysdate = models.DateTimeField(blank=True, null=True)
    class Meta:
        managed = False
        db_table = 'link_sensor_room_link'
        verbose_name_plural = "Связи датчиков"


Из-за взаимосвязей с другими таблицами и друг другом никак не удается их расположить так, что бы все работало - все время django не видит какое-то модели....

Может я что-то не так делаю, добавил лишних полей?
sensors_id и link_id - мои поля, которые я добавил в модели что бы реализовать many-to-many...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.04.2015, 19:00
Ответы с готовыми решениями:

ManyToMany связь, удаление
Здравствуйте. Не могу корректнопроизвести удаление, с есть сущности Project package com.sprsec.model; import javax.persistence.*; ...

Связь моделей ManyToMany
class Post(models.Model): post_caption = models.CharField(max_length=250) post_text = models.TextField() post_author_id =...

Связь ManyToMany - получить данные из связывающей таблицы
Всем трям. Есть две модели - Filmwork и Person, между ними связь many-to-many. Получаю список filmworks c persons чере...

1
 Аватар для Wolkodav
842 / 480 / 58
Регистрация: 18.09.2012
Сообщений: 1,688
21.04.2015, 02:49
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
class DimSensor(models.Model):
    sensid = models.CharField(primary_key=True, max_length=64)
    sensor_type_sid = models.ForeignKey('DirSensorType', db_column = 'sensor_type_sid')
    link_id = models.ManyToManyField('LinkRoomBedLink', through='LinkSensorRoomLink', through_fields=('sensid','room_bed_link_sid'), blank=True, null=True)
    def __unicode__(self):
        return self.sensid
    class Meta:
        managed = False
        db_table = 'dim_sensor'
        verbose_name_plural = "Список датчиков"   
 
class LinkRoomBedLink(models.Model):
    room_bed_link_sid = models.IntegerField(primary_key=True)
    lpu_id = models.ForeignKey('DirLpu', db_column = 'lpu_id', blank=True, null=True)
    dep_sid = models.ForeignKey('DirDep', db_column = 'dep_sid', blank=True, null=True)
    sensors_id = models.ManyToManyField('DimSensor', through='LinkSensorRoomLink', through_fields=('room_bed_link_sid', 'sensid'), blank=True, null=True)
    room_num = models.CharField(max_length=64, blank=True, null=True)
    bed_num = models.CharField(max_length=64, blank=True, null=True)
    sysdate = models.DateTimeField(blank=True, null=True)
    def __unicode__(self):
        return self.bed_num
    class Meta:
        managed = False
        db_table = 'link_room_bed_link'
        verbose_name_plural = "Палаты и койки"
 
class LinkSensorRoomLink(models.Model):
    sensor_room_link_sid = models.IntegerField(primary_key=True)
    room_bed_link_sid = models.ForeignKey('LinkRoomBedLink', db_column = 'room_bed_link_sid')
    sensid = models.ForeignKey('DimSensor', db_column = 'sensid')
    sysdate = models.DateTimeField(blank=True, null=True)
    class Meta:
        managed = False
        db_table = 'link_sensor_room_link'
        verbose_name_plural = "Связи датчиков"
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.04.2015, 02:49
Помогаю со студенческими работами здесь

Взаимное расположение множеств
Выяснить взаимное расположение множеств D, Е, F, если А, В, X - произвольные подмножества универсального множества U.

Взаимное расположение окон
Каким образом можно получить взаимное расположение окон в системе? То есть окно А находится над окном Б и т.д.

Взаимное расположение плоскостей
В пространстве Е5 определить взаимное расположение плоскостей {x}_{1} - {x}_{3}+{2x}_{4}-{x}_{5}+1=0 and \begin{cases} ...

Взаимное расположение треугольников
Не могу понять как можно вычислить если угол одного треугольника касается стороны другого треугольника, или угол вообще внутри треугольника...

Взаимное расположение прямых
1 задача: задано соотношение прямых a,b,c. В моем случае a ll b(прямая a параллельна прямой b) и b ll c(прямая b параллельна прямой c). ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru