|
@@ -1,23 +1,68 @@ |
|
|
CREATE DATABASE bitshift DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci; |
|
|
|
|
|
|
|
|
CREATE DATABASE `bitshift` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci; |
|
|
USE `bitshift`; |
|
|
USE `bitshift`; |
|
|
|
|
|
|
|
|
CREATE TABLE codelets ( |
|
|
|
|
|
|
|
|
CREATE TABLE `languages` ( |
|
|
|
|
|
`language_id` SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
|
|
|
`language_name` VARCHAR(64) NOT NULL, |
|
|
|
|
|
PRIMARY KEY (`language_id`) |
|
|
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE `origins` ( |
|
|
|
|
|
`origin_id` TINYINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
|
|
|
`origin_name` VARCHAR(64) NOT NULL, |
|
|
|
|
|
`origin_url` VARCHAR(512) NOT NULL, |
|
|
|
|
|
`origin_url_base` VARCHAR(512) NOT NULL, |
|
|
|
|
|
`origin_image` TINYBLOB DEFAULT NULL, -- TODO: verify size (<64kB) |
|
|
|
|
|
PRIMARY KEY (`origin_id`) |
|
|
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE `codelets` ( |
|
|
`codelet_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
`codelet_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
`codelet_name` VARCHAR(512) NOT NULL, |
|
|
`codelet_name` VARCHAR(512) NOT NULL, |
|
|
`codelet_code_id` BIGINT UNSIGNED NOT NULL, |
|
|
`codelet_code_id` BIGINT UNSIGNED NOT NULL, |
|
|
`codelet_lang` SMALLINT UNSIGNED DEFAULT NULL, |
|
|
|
|
|
`codelet_origin` TINYINT UNSIGNED DEFAULT NULL, |
|
|
|
|
|
|
|
|
`codelet_lang` SMALLINT UNSIGNED DEFAULT NULL, -- TODO: needs index |
|
|
|
|
|
`codelet_origin` TINYINT UNSIGNED NOT NULL, |
|
|
`codelet_url` VARCHAR(512) NOT NULL, |
|
|
`codelet_url` VARCHAR(512) NOT NULL, |
|
|
`codelet_date_created` DATETIME DEFAULT NULL, |
|
|
|
|
|
`codelet_date_modified` DATETIME DEFAULT NULL, |
|
|
|
|
|
|
|
|
`codelet_date_created` DATETIME DEFAULT NULL, -- TODO: needs index |
|
|
|
|
|
`codelet_date_modified` DATETIME DEFAULT NULL, -- TODO: needs index |
|
|
PRIMARY KEY (`codelet_id`) |
|
|
PRIMARY KEY (`codelet_id`) |
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
CREATE TABLE code ( |
|
|
|
|
|
|
|
|
CREATE TABLE `code` ( |
|
|
`code_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
`code_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
`code_hash` BIGINT NOT NULL, |
|
|
|
|
|
`code_code` MEDIUMTEXT NOT NULL, |
|
|
|
|
|
|
|
|
`code_hash` BIGINT NOT NULL, -- TODO: needs index |
|
|
|
|
|
`code_code` MEDIUMTEXT NOT NULL, -- TODO: verify size (16mB?) |
|
|
PRIMARY KEY (`code_id`) |
|
|
PRIMARY KEY (`code_id`) |
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE `authors` ( |
|
|
|
|
|
`author_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
|
|
|
`author_codelet` BIGINT UNSIGNED NOT NULL, -- TODO: foreign index? |
|
|
|
|
|
`author_name` VARCHAR(128) NOT NULL, -- TODO: needs index |
|
|
|
|
|
`author_url` VARCHAR(512) DEFAULT NULL, |
|
|
|
|
|
PRIMARY KEY (`author_id`) |
|
|
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE `symbols` ( |
|
|
|
|
|
`symbol_id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE, |
|
|
|
|
|
`symbol_codelet` BIGINT UNSIGNED NOT NULL, -- TODO: foreign index? |
|
|
|
|
|
`symbol_type` TINYINT UNSIGNED NOT NULL, -- TODO: multi-column index? |
|
|
|
|
|
`symbol_name` VARCHAR(512) NOT NULL, -- TODO: needs index |
|
|
|
|
|
`symbol_row` INT UNSIGNED NOT NULL, |
|
|
|
|
|
`symbol_col` INT UNSIGNED NOT NULL, |
|
|
|
|
|
PRIMARY KEY (`symbol_id`) |
|
|
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
CREATE TABLE `query_cache` ( |
|
|
|
|
|
`qcache_id` INT NOT NULL UNIQUE, |
|
|
|
|
|
`qcache_query` VARCHAR(512) NOT NULL, |
|
|
|
|
|
`qcache_results` BLOB NOT NULL, -- TODO: verify; perhaps use some kind of array |
|
|
|
|
|
`qcache_page` TINYINT UNSIGNED NOT NULL, |
|
|
|
|
|
`qcache_count_mnt` TINYINT UNSIGNED NOT NULL, |
|
|
|
|
|
`qcache_count_exp` TINYINT UNSIGNED NOT NULL, |
|
|
|
|
|
`qcache_created` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, -- TODO: verify |
|
|
|
|
|
`qcache_last_used` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, -- TODO: verify |
|
|
|
|
|
PRIMARY KEY (`cache_id`) |
|
|
|
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; |
|
|
|
|
|
|
|
|
|
|
|
-- TODO: full-text search index table |