mirror of
https://github.com/Oreolek/ifhub.club.git
synced 2024-07-16 21:34:25 +03:00
329 lines
14 KiB
SQL
329 lines
14 KiB
SQL
CREATE TABLE IF NOT EXISTS `prefix_topic_content` (
|
||
`topic_id` int(11) unsigned NOT NULL,
|
||
`topic_text` text collate utf8_bin NOT NULL,
|
||
`topic_text_short` text collate utf8_bin NOT NULL,
|
||
`topic_text_source` text collate utf8_bin NOT NULL,
|
||
`topic_extra` text collate utf8_bin NOT NULL,
|
||
PRIMARY KEY (`topic_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_topic_content`
|
||
--
|
||
ALTER TABLE `prefix_topic_content`
|
||
ADD CONSTRAINT `prefix_topic_content_fk` FOREIGN KEY (`topic_id`) REFERENCES `prefix_topic` (`topic_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_topic_question_vote`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_topic_question_vote` (
|
||
`topic_id` int(11) unsigned NOT NULL,
|
||
`user_voter_id` int(11) unsigned NOT NULL,
|
||
`answer` tinyint(4) NOT NULL,
|
||
UNIQUE KEY `topic_id_user_id` (`topic_id`,`user_voter_id`),
|
||
KEY `topic_id` (`topic_id`),
|
||
KEY `user_voter_id` (`user_voter_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_topic_question_vote`
|
||
--
|
||
ALTER TABLE `prefix_topic_question_vote`
|
||
ADD CONSTRAINT `prefix_topic_question_vote_fk1` FOREIGN KEY (`user_voter_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_topic_question_vote_fk` FOREIGN KEY (`topic_id`) REFERENCES `prefix_topic` (`topic_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
|
||
|
||
-- Меняем индекс в таблице комментов
|
||
ALTER TABLE `prefix_topic_comment` DROP INDEX `comment_date_rating` ;
|
||
ALTER TABLE `prefix_topic_comment` ADD INDEX `rating_date_id` ( `comment_rating` , `comment_date` , `comment_id` ) ;
|
||
ALTER TABLE `prefix_topic_comment` ADD INDEX ( `comment_date` ) ;
|
||
|
||
|
||
|
||
ALTER TABLE `prefix_topic_comment` ADD `comment_delete` TINYINT NOT NULL DEFAULT '0';
|
||
ALTER TABLE `prefix_topic_comment` ADD INDEX ( `comment_delete` ) ;
|
||
|
||
|
||
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_topic_comment_online`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_topic_comment_online` (
|
||
`comment_online_id` int(11) unsigned NOT NULL auto_increment,
|
||
`topic_id` int(11) unsigned NOT NULL,
|
||
`comment_id` int(11) unsigned NOT NULL,
|
||
PRIMARY KEY (`comment_online_id`),
|
||
KEY `topic_id` (`topic_id`),
|
||
KEY `comment_id` (`comment_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_topic_comment_online`
|
||
--
|
||
ALTER TABLE `prefix_topic_comment_online`
|
||
ADD CONSTRAINT `prefix_topic_comment_online_fk1` FOREIGN KEY (`comment_id`) REFERENCES `prefix_topic_comment` (`comment_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_topic_comment_online_fk` FOREIGN KEY (`topic_id`) REFERENCES `prefix_topic` (`topic_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
|
||
-- перевод некоторых полей в регистронезависимую кодировку
|
||
ALTER TABLE `prefix_topic_comment` CHANGE `comment_text` `comment_text` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_topic` CHANGE `topic_tags` `topic_tags` VARCHAR( 250 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT 'через запятую перечислены теги' ;
|
||
ALTER TABLE `prefix_topic_content` CHANGE `topic_text` `topic_text` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_topic_content` CHANGE `topic_text_short` `topic_text_short` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_topic_content` CHANGE `topic_text_source` `topic_text_source` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_topic_content` CHANGE `topic_extra` `topic_extra` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_topic_tag` CHANGE `topic_tag_text` `topic_tag_text` VARCHAR( 50 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_user` CHANGE `user_mail` `user_mail` VARCHAR( 50 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_user` CHANGE `user_login` `user_login` VARCHAR( 30 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_blog` CHANGE `blog_title` `blog_title` VARCHAR( 200 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ;
|
||
ALTER TABLE `prefix_blog` CHANGE `blog_url` `blog_url` VARCHAR( 200 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ;
|
||
|
||
|
||
-- новое поле для принудительного вывода топика на главную страницу
|
||
ALTER TABLE `prefix_topic` ADD `topic_publish_index` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `topic_publish` ;
|
||
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_invite`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_invite` (
|
||
`invite_id` int(11) unsigned NOT NULL auto_increment,
|
||
`invite_code` varchar(32) collate utf8_bin NOT NULL,
|
||
`user_from_id` int(11) unsigned NOT NULL,
|
||
`user_to_id` int(11) unsigned default NULL,
|
||
`invite_date_add` datetime NOT NULL,
|
||
`invite_date_used` datetime NOT NULL,
|
||
`invite_used` tinyint(1) unsigned NOT NULL default '0',
|
||
PRIMARY KEY (`invite_id`),
|
||
UNIQUE KEY `invite_code` (`invite_code`),
|
||
KEY `user_from_id` (`user_from_id`),
|
||
KEY `user_to_id` (`user_to_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_invite`
|
||
--
|
||
ALTER TABLE `prefix_invite`
|
||
ADD CONSTRAINT `prefix_invite_fk` FOREIGN KEY (`user_from_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_invite_fk1` FOREIGN KEY (`user_to_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
ALTER TABLE `prefix_invite` ADD INDEX ( `invite_date_add` ) ;
|
||
|
||
|
||
-- Дополнительные поля настройки у юзера
|
||
ALTER TABLE `prefix_user` ADD `user_settings_notice_new_topic` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
ALTER TABLE `prefix_user` ADD `user_settings_notice_new_comment` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
ALTER TABLE `prefix_user` ADD `user_settings_notice_new_talk` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
ALTER TABLE `prefix_user` ADD `user_settings_notice_reply_comment` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
|
||
|
||
|
||
ALTER TABLE `prefix_blog` ADD INDEX ( `blog_title` ) ;
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_page`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_page` (
|
||
`page_id` int(11) unsigned NOT NULL auto_increment,
|
||
`page_pid` int(11) unsigned default NULL,
|
||
`page_url` varchar(50) NOT NULL,
|
||
`page_url_full` varchar(254) NOT NULL,
|
||
`page_title` varchar(200) NOT NULL,
|
||
`page_text` text NOT NULL,
|
||
`page_date_add` datetime NOT NULL,
|
||
`page_date_edit` datetime default NULL,
|
||
`page_seo_keywords` varchar(250) default NULL,
|
||
`page_seo_description` varchar(250) default NULL,
|
||
`page_active` tinyint(1) unsigned NOT NULL default '1',
|
||
PRIMARY KEY (`page_id`),
|
||
KEY `page_pid` (`page_pid`),
|
||
KEY `page_url_full` (`page_url_full`,`page_active`),
|
||
KEY `page_title` (`page_title`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_page`
|
||
--
|
||
ALTER TABLE `prefix_page`
|
||
ADD CONSTRAINT `prefix_page_fk` FOREIGN KEY (`page_pid`) REFERENCES `prefix_page` (`page_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
|
||
|
||
|
||
-- делаем индекс уникальным, а не просто индексом
|
||
ALTER TABLE `prefix_topic_read` DROP INDEX `topic_id_user_id` ,
|
||
ADD UNIQUE `topic_id_user_id` ( `topic_id` , `user_id` ) ;
|
||
|
||
-- новое поле для текста КАТа
|
||
ALTER TABLE `prefix_topic` ADD `topic_cut_text` VARCHAR( 100 ) NULL ;
|
||
|
||
|
||
-- новое поле для запрета комментов в топике
|
||
ALTER TABLE `prefix_topic` ADD `topic_forbid_comment` TINYINT( 1 ) NOT NULL DEFAULT '0';
|
||
|
||
|
||
-- новое поле для хранения хеша текста коммента
|
||
ALTER TABLE `prefix_topic_comment` ADD `comment_text_hash` VARCHAR( 32 ) NOT NULL AFTER `comment_text` ;
|
||
|
||
|
||
ALTER TABLE `prefix_user` CHANGE `user_profile_avatar_type` `user_profile_avatar_type` VARCHAR( 5 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ;
|
||
|
||
-- поля для аватара блога
|
||
ALTER TABLE `prefix_blog` ADD `blog_avatar` TINYINT( 1 ) UNSIGNED NOT NULL DEFAULT '0';
|
||
ALTER TABLE `prefix_blog` ADD `blog_avatar_type` VARCHAR( 5 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL ;
|
||
|
||
|
||
-- поле для хранения даты последнего коммента, оставленого юзером
|
||
ALTER TABLE `prefix_user` ADD `user_date_comment_last` DATETIME NULL AFTER `user_date_activate` ;
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_topic_comment_last`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_topic_comment_last` (
|
||
`topic_id` int(11) unsigned NOT NULL,
|
||
`user_id` int(11) unsigned NOT NULL,
|
||
`comment_count_last` int(11) unsigned NOT NULL,
|
||
`date_last` datetime NOT NULL,
|
||
UNIQUE KEY `user_id_topic_id` (`user_id`,`topic_id`),
|
||
KEY `topic_id` (`topic_id`),
|
||
KEY `user_id` (`user_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_topic_comment_last`
|
||
--
|
||
ALTER TABLE `prefix_topic_comment_last`
|
||
ADD CONSTRAINT `prefix_topic_comment_new_fk` FOREIGN KEY (`user_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_topic_comment_new_fk1` FOREIGN KEY (`topic_id`) REFERENCES `prefix_topic` (`topic_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
|
||
-- новое поля для настройки уведомления о новом друге
|
||
ALTER TABLE `prefix_user` ADD `user_settings_notice_new_friend` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
|
||
|
||
-- изменяем имя таблицы на правильное с точки зрения грамотеев английского языка..
|
||
RENAME TABLE `prefix_frend` TO `prefix_friend` ;
|
||
|
||
|
||
-- добавляем уникальный индекс
|
||
ALTER TABLE `prefix_topic_comment_online` DROP INDEX `topic_id` ,
|
||
ADD UNIQUE `topic_id` ( `topic_id` ) ;
|
||
|
||
|
||
--
|
||
-- Структура таблицы `prefix_city`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_city` (
|
||
`city_id` int(11) unsigned NOT NULL auto_increment,
|
||
`city_name` varchar(30) NOT NULL,
|
||
PRIMARY KEY (`city_id`),
|
||
KEY `city_name` (`city_name`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
-- --------------------------------------------------------
|
||
|
||
--
|
||
-- Структура таблицы `prefix_city_user`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_city_user` (
|
||
`city_id` int(11) unsigned NOT NULL,
|
||
`user_id` int(11) unsigned NOT NULL,
|
||
UNIQUE KEY `user_id` (`user_id`),
|
||
KEY `city_id` (`city_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
-- --------------------------------------------------------
|
||
|
||
--
|
||
-- Структура таблицы `prefix_country`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_country` (
|
||
`country_id` int(11) unsigned NOT NULL auto_increment,
|
||
`country_name` varchar(30) NOT NULL,
|
||
PRIMARY KEY (`country_id`),
|
||
KEY `country_name` (`country_name`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
-- --------------------------------------------------------
|
||
|
||
--
|
||
-- Структура таблицы `prefix_country_user`
|
||
--
|
||
|
||
CREATE TABLE IF NOT EXISTS `prefix_country_user` (
|
||
`country_id` int(11) unsigned NOT NULL,
|
||
`user_id` int(11) unsigned NOT NULL,
|
||
UNIQUE KEY `user_id` (`user_id`),
|
||
KEY `country_id` (`country_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа сохраненных таблиц
|
||
--
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_city_user`
|
||
--
|
||
ALTER TABLE `prefix_city_user`
|
||
ADD CONSTRAINT `prefix_city_user_fk` FOREIGN KEY (`city_id`) REFERENCES `prefix_city` (`city_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_city_user_fk1` FOREIGN KEY (`user_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
--
|
||
-- Ограничения внешнего ключа таблицы `prefix_country_user`
|
||
--
|
||
ALTER TABLE `prefix_country_user`
|
||
ADD CONSTRAINT `prefix_country_user_fk` FOREIGN KEY (`country_id`) REFERENCES `prefix_country` (`country_id`) ON DELETE CASCADE ON UPDATE CASCADE,
|
||
ADD CONSTRAINT `prefix_country_user_fk1` FOREIGN KEY (`user_id`) REFERENCES `prefix_user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
||
-- Дополнительное поле для избранного
|
||
ALTER TABLE `prefix_favourite_topic` ADD `topic_publish` TINYINT( 1 ) NOT NULL DEFAULT '1';
|
||
|
||
ALTER TABLE `prefix_favourite_topic` ADD INDEX ( `topic_publish` ) ;
|
||
|
||
|
||
|
||
--
|
||
-- ВНИМАНИЕ!!! То что ниже нужно выполнить только после запуска скрипта convert.php !!!! иначе УДАЛЯТСЯ ВСЕ ТОПИКИ!!!!!
|
||
--
|
||
|
||
ALTER TABLE `prefix_topic` DROP `topic_text` ;
|
||
ALTER TABLE `prefix_topic` DROP `topic_text_short` ;
|
||
ALTER TABLE `prefix_topic` DROP `topic_text_source` ;
|
||
ALTER TABLE `prefix_topic` CHANGE `topic_tags` `topic_tags` VARCHAR( 250 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT 'через запятую перечислены теги' ; |