聊天记录数据库表结构怎么设计?
关于聊天记录数据库表结构设计
1、首先表结构设计针对单个用户,然后拓展到n个用用户记录的存储。
2、这里会用msql数据库给出数据库表脚本,但是实际生产环境应该是在APP端生成sqlite数据库文件,把sqlite文件上传到server端作为聊天记录存储。
有【联系人表】、【群组表】、【会话表】、【用户表】、【聊天记录表】
# 聊天记录表
CREATE TABLE `message` ( `msg_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '消息id,自增长', `msg_type` int(11) DEFAULT NULL COMMENT '类型 1:文字;47:emoji;43:音频;436207665:红包;49:文件;48:位置;3:图片', `is_send` int(11) DEFAULT NULL COMMENT '是否是自己发送 0:不是;1:是', `create_time` datetime DEFAULT NULL COMMENT '消息发送时间', `content` text COMMENT '消息格式【发信人id:内容】', `talker` varchar(55) DEFAULT NULL COMMENT '聊天对象。群聊,则是群id(xxx@chatroom);一对一,聊天对象的唯一标识。', PRIMARY KEY (`msg_id`), KEY `index_chat_id` (`talker`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
注意⚠️ content:不是自己发送的消息,并且是群聊,才会带有发信人id标记。
msg_id在同一个账户切换了设备后产生的msg_id可能是重复的,所以在聊天记录存储在server端时需要注意到这一点。
#联系人表
CREATE TABLE `recontact` ( `username` varchar(45) NOT NULL COMMENT '联系人唯一标识', `nickname` varchar(45) DEFAULT NULL COMMENT '联系人昵称', `remark` varchar(45) DEFAULT NULL COMMENT '备注名称', `avatar` varchar(200) DEFAULT NULL COMMENT '联系人头像地址', `is_friend` varchar(45) DEFAULT NULL COMMENT '是否是好友。1,3 好友 4;群里非好友', PRIMARY KEY (`username`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='联系人,非好友';
联系人表存储了好友以及非好友。
#群组表
CREATE TABLE `chat_room` ( `chat_room_name` varchar(30) CHARACTER SET utf8mb4 NOT NULL, `member_list` text CHARACTER SET utf8mb4 COMMENT '群组成员id列表,分号分割。a53255001;nan1242;jiabailo002', `display_name_list` text CHARACTER SET utf8mb4 COMMENT '群成员昵称列表【中文顿号分割】海、二、老僧、刘伟、齐彬、毛、Echo、曹', `room_owner` varchar(45) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '群主id', `self_display_name` varchar(45) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '自己在群里的自定义群昵称', `chat_room_nick` varchar(45) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '群昵称,没有自定义群昵称则从display_name中截取20个字符作为群昵称。', PRIMARY KEY (`chat_room_name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin COMMENT='群组';
chat_room_name为群id,格式为xxx@chatroom
#用户表
CREATE TABLE `users` ( `id` varchar(45) NOT NULL COMMENT '用户id', `nickname` varchar(45) DEFAULT NULL, `email` varchar(45) DEFAULT NULL, `sign` varchar(200) DEFAULT NULL COMMENT '签名', `city` varchar(45) DEFAULT NULL, `provincial` varchar(45) DEFAULT NULL COMMENT '省份', `avatar_url` varchar(500) DEFAULT NULL COMMENT '头像', `created_at` datetime DEFAULT NULL, `updated_at` datetime DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `id_UNIQUE` (`id`), KEY `index_updated_at` (`updated_at`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户';
更多相关知识,请访问PHP中文网!

phpisusedforsendendemailsduetoitsignegrationwithservermailservicesand andexternalsmtpproviders,自动化notifications andMarketingCampaigns.1)设置设置yourphpenvironcormentswironmentswithaweberswithawebserverserverserverandphp,确保themailfunctionisenabled.2)useabasicscruct

发送电子邮件的最佳方法是使用PHPMailer库。1)使用mail()函数简单但不可靠,可能导致邮件进入垃圾邮件或无法送达。2)PHPMailer提供更好的控制和可靠性,支持HTML邮件、附件和SMTP认证。3)确保正确配置SMTP设置并使用加密(如STARTTLS或SSL/TLS)以增强安全性。4)对于大量邮件,考虑使用邮件队列系统来优化性能。

CustomHeadersheadersandAdvancedFeaturesInphpeMailenHanceFunctionalityAndreliability.1)CustomHeadersheadersheadersaddmetadatatatatataatafortrackingandCategorization.2)htmlemailsallowformattingandttinganditive.3)attachmentscanmentscanmentscanbesmentscanbestmentscanbesentscanbesentingslibrarieslibrarieslibrariesliblarikelikephpmailer.4)smtppapapairatienticationaltication enterticationallimpr

使用PHP和SMTP发送邮件可以通过PHPMailer库实现。1)安装并配置PHPMailer,2)设置SMTP服务器细节,3)定义邮件内容,4)发送邮件并处理错误。使用此方法可以确保邮件的可靠性和安全性。

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

使用依赖注入(DI)的原因是它促进了代码的松耦合、可测试性和可维护性。1)使用构造函数注入依赖,2)避免使用服务定位器,3)利用依赖注入容器管理依赖,4)通过注入依赖提高测试性,5)避免过度注入依赖,6)考虑DI对性能的影响。

phperformancetuningiscialbecapeitenhancesspeedandeffice,whatevitalforwebapplications.1)cachingwithapcureduccureducesdatabaseloadprovesrovesponsemetimes.2)优化

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

记事本++7.3.1
好用且免费的代码编辑器

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

禅工作室 13.0.1
功能强大的PHP集成开发环境