Найти - Пользователи
Полная версия: Поле AUTO_INCREMENT в промежуточной таблице many-to-many
Начало » Django » Поле AUTO_INCREMENT в промежуточной таблице many-to-many
1
eug
С django работаю всего второй день. Заметил одну ообенность. При создании связи Many-to-Many создается промежуточная таблица в которой кроме уникального индекса создается ещё автоинкрементное поле.

class Category(models.Model):
name = models.CharField(max_length=255)

class Post(models.Model):
title = models.CharField(max_length=255)
description = models.TextField()
post = models.TextField()
pub_date = models.DateField()
categories = models.ManyToManyField(Category, blank=True)
BEGIN;
CREATE TABLE `posts_category` (
`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`name` varchar(255) NOT NULL
)
;
CREATE TABLE `posts_post` (
`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`title` varchar(255) NOT NULL,
`description` longtext NOT NULL,
`post` longtext NOT NULL,
`pub_date` date NOT NULL
)
;
CREATE TABLE `posts_post_categories` (
`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY,
`post_id` integer NOT NULL,
`category_id` integer NOT NULL,
UNIQUE (`post_id`, `category_id`)
)
;
ALTER TABLE `posts_post_categories` ADD CONSTRAINT `post_id_refs_id_2bd0ebb3` FOREIGN KEY (`post_id`) REFERENCES `posts_post` (`id`);
ALTER TABLE `posts_post_categories` ADD CONSTRAINT `category_id_refs_id_65af7dcb` FOREIGN KEY (`category_id`) REFERENCES `posts_category` (`id`);
COMMIT;
для чего оно нужно, ведь помоему индекса:
UNIQUE (`post_id`, `category_id`)
вполне достаточно

Спасибо.
Александр Кошелев
eug
для чего оно нужно, ведь помоему индекса:
Для того чтобы у связи строго был первичный ключ из одного поля. С композитными первичными ключами Джанга работать не умеет (пока).
eug
я думал она все может ) Спасибо.
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