You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
84 lines
3.8 KiB
84 lines
3.8 KiB
CREATE DATABASE chat;
|
|
|
|
DROP TABLE IF EXISTS `users`;
|
|
CREATE TABLE IF NOT EXISTS `users` (
|
|
`id` int NOT NULL AUTO_INCREMENT COMMENT 'id',
|
|
`uuid` varchar(150) NOT NULL COMMENT 'uuid',
|
|
`username` varchar(191) NOT NULL COMMENT '''用户名''',
|
|
`nickname` varchar(255) DEFAULT NULL COMMENT '昵称',
|
|
`email` varchar(80) DEFAULT NULL COMMENT '邮箱',
|
|
`password` varchar(150) NOT NULL COMMENT '密码',
|
|
`avatar` varchar(250) NOT NULL COMMENT '头像',
|
|
`create_at` datetime(3) DEFAULT NULL,
|
|
`update_at` datetime(3) DEFAULT NULL,
|
|
`delete_at` bigint DEFAULT NULL,
|
|
PRIMARY KEY (`id`),
|
|
UNIQUE KEY `username` (`username`),
|
|
UNIQUE KEY `idx_uuid` (`uuid`),
|
|
UNIQUE KEY `username_2` (`username`)
|
|
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci COMMENT '用户表';
|
|
|
|
|
|
DROP TABLE IF EXISTS `user_friends`;
|
|
CREATE TABLE IF NOT EXISTS `user_friends` (
|
|
`id` int NOT NULL AUTO_INCREMENT COMMENT 'id',
|
|
`created_at` datetime(3) DEFAULT NULL COMMENT '创建时间',
|
|
`updated_at` datetime(3) DEFAULT NULL COMMENT '更新时间',
|
|
`deleted_at` bigint unsigned DEFAULT NULL COMMENT '删除时间戳',
|
|
`user_id` int DEFAULT NULL COMMENT '用户ID',
|
|
`friend_id` int DEFAULT NULL COMMENT '好友ID',
|
|
PRIMARY KEY (`id`),
|
|
KEY `idx_user_friends_user_id` (`user_id`),
|
|
KEY `idx_user_friends_friend_id` (`friend_id`)
|
|
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci COMMENT '好友信息表';
|
|
|
|
|
|
DROP TABLE IF EXISTS `messages`;
|
|
CREATE TABLE IF NOT EXISTS `messages` (
|
|
`id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',
|
|
`created_at` datetime(3) DEFAULT NULL COMMENT '创建时间',
|
|
`updated_at` datetime(3) DEFAULT NULL COMMENT '更新时间',
|
|
`deleted_at` bigint unsigned DEFAULT NULL COMMENT '删除时间戳',
|
|
`from_user_id` int DEFAULT NULL COMMENT '发送人ID',
|
|
`to_user_id` int DEFAULT NULL COMMENT '发送对象ID',
|
|
`content` varchar(2500) DEFAULT NULL COMMENT '消息内容',
|
|
`url` varchar(350) DEFAULT NULL COMMENT '''文件或者图片地址''',
|
|
`pic` text COMMENT '缩略图',
|
|
`message_type` smallint DEFAULT NULL COMMENT '''消息类型:1单聊,2群聊''',
|
|
`content_type` smallint DEFAULT NULL COMMENT '''消息内容类型:1文字,2语音,3视频''',
|
|
PRIMARY KEY (`id`),
|
|
KEY `idx_messages_deleted_at` (`deleted_at`),
|
|
KEY `idx_messages_from_user_id` (`from_user_id`),
|
|
KEY `idx_messages_to_user_id` (`to_user_id`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT '消息表';
|
|
|
|
|
|
DROP TABLE IF EXISTS `groups`;
|
|
CREATE TABLE IF NOT EXISTS `groups` (
|
|
`id` int NOT NULL AUTO_INCREMENT,
|
|
`created_at` datetime(3) DEFAULT NULL,
|
|
`updated_at` datetime(3) DEFAULT NULL,
|
|
`deleted_at` bigint unsigned DEFAULT NULL,
|
|
`user_id` int DEFAULT NULL COMMENT '''群主ID''',
|
|
`name` varchar(150) DEFAULT NULL COMMENT '''群名称',
|
|
`notice` varchar(350) DEFAULT NULL COMMENT '''群公告',
|
|
`uuid` varchar(150) NOT NULL COMMENT '''uuid''',
|
|
PRIMARY KEY (`id`),
|
|
KEY `idx_groups_user_id` (`user_id`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT '群组表';
|
|
|
|
|
|
DROP TABLE IF EXISTS `group_members`;
|
|
CREATE TABLE IF NOT EXISTS `group_members` (
|
|
`id` int NOT NULL AUTO_INCREMENT,
|
|
`created_at` datetime(3) DEFAULT NULL,
|
|
`updated_at` datetime(3) DEFAULT NULL,
|
|
`deleted_at` bigint unsigned DEFAULT NULL,
|
|
`user_id` int DEFAULT NULL COMMENT '''用户ID''',
|
|
`group_id` int DEFAULT NULL COMMENT '''群组ID''',
|
|
`nickname` varchar(350) DEFAULT NULL COMMENT '''昵称',
|
|
`mute` smallint DEFAULT NULL COMMENT '''是否禁言''',
|
|
PRIMARY KEY (`id`),
|
|
KEY `idx_group_members_user_id` (`user_id`),
|
|
KEY `idx_group_members_group_id` (`group_id`)
|
|
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT '群组成员表';
|
|
|