| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  | SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
 | 
					
						
							|  |  |  | SET time_zone = "+00:00";
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `deleted_words` (
 | 
					
						
							|  |  |  |   `dictionary` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   `word_id` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   `deleted_on` int(11) NOT NULL
 | 
					
						
							|  |  |  | ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `dictionaries` (
 | 
					
						
							|  |  |  |   `id` int(11) NOT NULL AUTO_INCREMENT,
 | 
					
						
							|  |  |  |   `user` int(11) NOT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-05-17 11:39:00 -06:00
										 |  |  |   `name` varchar(80) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'New',
 | 
					
						
							|  |  |  |   `specification` varchar(80) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'Dictionary',
 | 
					
						
							|  |  |  |   `description` text COLLATE utf8_unicode_ci NOT NULL COMMENT 'Markdown. Default: "A new dictionary."',
 | 
					
						
							| 
									
										
										
										
											2019-05-14 17:11:23 -06:00
										 |  |  |   `allow_duplicates` tinyint(1) NOT NULL DEFAULT 0,
 | 
					
						
							|  |  |  |   `case_sensitive` tinyint(1) NOT NULL DEFAULT 0,
 | 
					
						
							|  |  |  |   `sort_by_definition` tinyint(1) NOT NULL DEFAULT 0,
 | 
					
						
							| 
									
										
										
										
											2019-05-31 13:04:49 -06:00
										 |  |  |   `theme` varchar(20) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'default',
 | 
					
						
							| 
									
										
										
										
											2019-05-14 17:11:23 -06:00
										 |  |  |   `is_public` tinyint(1) NOT NULL DEFAULT 0,
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   `last_updated` int(11) DEFAULT NULL,
 | 
					
						
							|  |  |  |   `created_on` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   PRIMARY KEY (`id`)
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  | ) ENGINE=MyISAM AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  | DELIMITER $$
 | 
					
						
							|  |  |  | CREATE TRIGGER IF NOT EXISTS `delete_dictionary_parts` AFTER DELETE ON `dictionaries` FOR EACH ROW BEGIN
 | 
					
						
							|  |  |  | 	DELETE FROM words WHERE words.dictionary=old.id;
 | 
					
						
							|  |  |  | 	DELETE FROM dictionary_linguistics WHERE dictionary_linguistics.dictionary=old.id;
 | 
					
						
							|  |  |  | 	DELETE FROM deleted_words WHERE deleted_words.dictionary=old.id;
 | 
					
						
							|  |  |  | END
 | 
					
						
							|  |  |  | $$
 | 
					
						
							|  |  |  | DELIMITER ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `dictionary_linguistics` (
 | 
					
						
							|  |  |  |   `dictionary` int(11) NOT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  |   `parts_of_speech` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'Comma-separated',
 | 
					
						
							|  |  |  |   `consonants` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Space-separated',
 | 
					
						
							|  |  |  |   `vowels` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Space-separated',
 | 
					
						
							|  |  |  |   `blends` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Space-separated',
 | 
					
						
							|  |  |  |   `onset` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Comma-separated',
 | 
					
						
							|  |  |  |   `nucleus` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Comma-separated',
 | 
					
						
							|  |  |  |   `coda` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' COMMENT 'Comma-separated',
 | 
					
						
							| 
									
										
										
										
											2019-07-05 11:44:53 -06:00
										 |  |  |   `phonotactics_notes` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'Markdown',
 | 
					
						
							| 
									
										
										
										
											2019-07-07 00:00:53 -06:00
										 |  |  |   `translations` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'Newline-separated; Translates left character(s) to right character(s)',
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  |   `orthography_notes` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'Markdown',
 | 
					
						
							|  |  |  |   `grammar_notes` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'Markdown',
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   UNIQUE KEY `dictionary` (`dictionary`)
 | 
					
						
							|  |  |  | ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `memberships` (
 | 
					
						
							|  |  |  |   `id` int(11) NOT NULL AUTO_INCREMENT,
 | 
					
						
							|  |  |  |   `user` int(11) NOT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-05-14 17:11:23 -06:00
										 |  |  |   `start_date` timestamp NOT NULL DEFAULT current_timestamp(),
 | 
					
						
							|  |  |  |   `expire_date` timestamp NOT NULL DEFAULT current_timestamp(),
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   PRIMARY KEY (`id`)
 | 
					
						
							|  |  |  | ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `users` (
 | 
					
						
							|  |  |  |   `id` int(11) NOT NULL AUTO_INCREMENT,
 | 
					
						
							|  |  |  |   `email` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
 | 
					
						
							|  |  |  |   `old_password` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
 | 
					
						
							|  |  |  |   `password` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL,
 | 
					
						
							|  |  |  |   `public_name` varchar(50) COLLATE utf8_unicode_ci NOT NULL DEFAULT 'Someone',
 | 
					
						
							|  |  |  |   `current_dictionary` int(11) DEFAULT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-05-14 17:11:23 -06:00
										 |  |  |   `allow_email` tinyint(1) NOT NULL DEFAULT 1,
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  |   `last_login` datetime DEFAULT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   `password_reset_code` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  |   `password_reset_date` timestamp NULL DEFAULT NULL,
 | 
					
						
							|  |  |  |   `created_on` datetime DEFAULT current_timestamp(),
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   PRIMARY KEY (`id`),
 | 
					
						
							|  |  |  |   UNIQUE KEY `email` (`email`)
 | 
					
						
							| 
									
										
										
										
											2019-06-07 14:43:49 -06:00
										 |  |  | ) ENGINE=MyISAM AUTO_INCREMENT=500 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  | DELIMITER $$
 | 
					
						
							|  |  |  | CREATE TRIGGER IF NOT EXISTS `Delete_User_Dictionaries` AFTER DELETE ON `users` FOR EACH ROW DELETE FROM dictionaries WHERE dictionaries.user = old.id
 | 
					
						
							|  |  |  | $$
 | 
					
						
							|  |  |  | DELIMITER ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CREATE TABLE IF NOT EXISTS `words` (
 | 
					
						
							|  |  |  |   `dictionary` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   `word_id` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   `name` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
 | 
					
						
							|  |  |  |   `pronunciation` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
 | 
					
						
							|  |  |  |   `part_of_speech` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
 | 
					
						
							| 
									
										
										
										
											2019-05-17 11:39:00 -06:00
										 |  |  |   `definition` text COLLATE utf8_unicode_ci NOT NULL,
 | 
					
						
							|  |  |  |   `details` text COLLATE utf8_unicode_ci NOT NULL COMMENT 'Markdown',
 | 
					
						
							| 
									
										
										
										
											2019-05-14 15:01:17 -06:00
										 |  |  |   `last_updated` int(11) DEFAULT NULL,
 | 
					
						
							|  |  |  |   `created_on` int(11) NOT NULL,
 | 
					
						
							|  |  |  |   UNIQUE KEY `unique_index` (`dictionary`,`word_id`)
 | 
					
						
							|  |  |  | ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 |