私信消息基本功能数据库设计
本文通过数据库层面来解析私信消息基本功能的实现。
项目需求:私信功能,实现像对方发送私信消息后,在我的私信列表页面显示与发送或者接受消息的人列表,列表每条记录只显示与该对话的最新的一条消息。 点击列表中的任意一条,进入到消息对话详情页面,按照倒序显示该对话的详细内容。同时在这两个页面都可以进行删除对话,私信列表页面删除是与对方的所有会话,私信详情页面删除的是某一条对话,而且单方删除对话记录,不影响对方查看。
软件环境: mysql
说了这么多,其实总结起来就那么几个重要的点,一是私信列表每条记录只显示最后一条记录,二是单方删除对话记录,不影响对方查看。先上数据表,然后在逐一解释下。
CREATE TABLE `private_message` ( `id` bigint(20) NOT NULL auto_increment COMMENT '主键Id', `user_id` bigint(20) NOT NULL COMMENT '发送者Id', `friend_id` bigint(20) NOT NULL COMMENT '接受者Id', `sender_id` bigint(20) NOT NULL COMMENT '发送者id', `receiver_id` bigint(20) NOT NULL COMMENT '接受者Id', `message_type` tinyint(4) NOT NULL COMMENT '消息类型,1:普通消息 2:系统消息', `message_content` varchar(500) NOT NULL COMMENT '消息内容', `send_time` datetime NOT NULL COMMENT '消息发送时间', `status` tinyint(4) NOT NULL default '1' COMMENT '消息状态 1:未读 2:已读 3:删除', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;123456789101112
建立private_message表,字段说明:
id:主键,自增长 user_id: 发送者id,非真实发送者id friend_id: 接受者id,非真实接受者id sender_id:发送者id,真实的发送者id receiver_id:接受者id,真实的接受者id message_type:消息类型,1:普通消息 2:系统消息,区分消息列表,可以发送不同类型的消息内容 message_content:消息内容 send_time:消息发送时间 status:消息状态 1:未读 2:已读 3:删除,标记不同消息状态,可以实现统计未读消息数,逻辑删除用户恢复等
看到这里大家该郁闷了,怎么弄两个发送者id,接受者id呢?
这里因为考虑到单方删除记录,不影响对方查看的功能,所以这里面我们需要在发送私信时,插入两份一样content内容的数据,但是在user_id,friend_id上面做点手脚了,在两次插入数据时,第二次插入的数据跟第一次插入的数据的user_id和friend_id对调。也就是:
INSERT INTO `private_message` VALUES ('1', '121', '127', '121', '127', '1', 'hello word', '2015-09-09 10:25:43', '2');INSERT INTO `private_message` VALUES ('2', '127', '121', '121', '127', '1', 'hello word', '2015-09-09 10:26:41', '1');INSERT INTO `private_message` VALUES ('3', '127', '121', '127', '121', '1', '你是程序猿吗?', '2015-09-11 10:30:16', '2');INSERT INTO `private_message` VALUES ('4', '121', '127', '127', '121', '1', '你是程序猿吗?', '2015-09-11 10:30:59', '2');1234
这么一来,就可以满足我们的需求了。第一条和第四条记录是给121用户看,第二条和第三条记录是给127看的,121删除的时候删除第一条或者第四条记录,当然不会影响127看第二条和第三条记录啦!!!
好了,现在可以搞定其他的功能需求了。
1、我的私信列表
SELECT p.id, COUNT(p.id) AS message_count,p.user_id,p.friend_id,p.sender_id,p.receiver_id,p.send_time,p.message_content, u.`name` AS receiver_name,u.img_url AS receiver_image FROM (SELECT * FROM private_message ORDER BY id DESC) p INNER JOIN user u on u.id=friend_id WHERE p.user_id=121 and p.`status` !=3 GROUP BY p.friend_id ORDER BY p.id DESC limit 0,101
2、我的私信列表详情
SELECT p.id,p.message_content,p.sender_id,p.receiver_id,p.send_time,u.`name` AS sender_name,u.img_url AS sender_image,uu.`name` AS receiver_name FROM private_message p INNER JOIN user u on u.id=p.sender_id INNER JOIN user uu on uu.id=p.friend_id WHERE p.user_id=121 and p.friend_id=127 and p.`status` !=3 ORDER BY p.id DESC limit 0,101
3、我的私信列表页面删除整个会话
UPDATE private_message SETstatus=3 WHERE user_id=121 AND friend_id=1271
4、我的私信列表详情删除单个对话
UPDATE private_message SET status=3 WHERE id=11
5、获取用户未读消息数量
SELECT COUNT(*) FROM private_message WHERE user_id=121 AND receiver_id=127 AND status=11
当然,还可以更新未读消息为已读,将已删除的用户从回收站中恢复过来,发送系统消息等等都可以实现的啦。这是,肯定有同学会说了,这个表设计的数据冗余,每条记录插入两遍,content内容多的话或者发送系统消息时,表数据太大,当然这个只是针对小型的私信功能,肯定跟大型专注于社交类网站不一样了,但是我们也可以将content内容拆分出去,新建一个content表,这里关联下id就可以减少数据冗余了。还有就是这个设计不涉及到高并发访问啦!涉及到高并发这个那就得更复杂的设计和方法途径解决啦!
相关阅读:
以上就是本文的全部内容,如果有疑问,欢迎在评论区留言!
Atas ialah kandungan terperinci 私信消息基本功能数据库设计. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



1. Buka apl Douyin, klik [Mesej] di bahagian bawah antara muka dan klik entri perbualan sembang yang perlu dipadamkan. 2. Tekan lama mana-mana rekod sembang, klik [Multiple Select], dan semak rekod sembang yang ingin anda padamkan. 3. Klik butang [Padam] di penjuru kanan sebelah bawah dan pilih [Sahkan pemadaman] dalam tetingkap pop timbul untuk memadam rekod ini secara kekal.

1. Apabila pengguna memadamkan rekod sembang mesej peribadi Douyin, biasanya rekod ini tidak boleh dipulihkan kerana ia adalah pemadaman kekal. 2. Walau bagaimanapun, pengguna boleh menghubungi rasmi Douyin dan cuba berkomunikasi untuk memulihkan sejarah sembang. 3. Buka apl Douyin, klik tiga bar mendatar di penjuru kanan sebelah atas antara muka [Saya], pilih [Settings], slaid ke bawah dan klik [About Douyin]. 4. Cari dan hubungi [Customer Service Hotline], atau hubungi pegawai Douyin melalui e-mel rasmi untuk mengetahui tentang kemungkinan memulihkan rekod sembang.

Bahasa Go ialah bahasa pengaturcaraan yang cekap, ringkas dan mudah dipelajari Ia digemari oleh pembangun kerana kelebihannya dalam pengaturcaraan serentak dan pengaturcaraan rangkaian. Dalam pembangunan sebenar, operasi pangkalan data adalah bahagian yang sangat diperlukan Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Dalam bahasa Go, kami biasanya menggunakan perpustakaan pihak ketiga untuk mengendalikan pangkalan data, seperti pakej sql yang biasa digunakan, gorm, dsb. Di sini kami mengambil pakej sql sebagai contoh untuk memperkenalkan cara melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Andaikan kami menggunakan pangkalan data MySQL.

Pemetaan polimorfik hibernate boleh memetakan kelas yang diwarisi ke pangkalan data dan menyediakan jenis pemetaan berikut: subkelas bercantum: Cipta jadual berasingan untuk subkelas, termasuk semua lajur kelas induk. table-per-class: Cipta jadual berasingan untuk subkelas, yang mengandungi hanya lajur khusus subkelas. union-subclass: serupa dengan joined-subclass, tetapi jadual kelas induk menggabungkan semua lajur subclass.

Keluaran terbaharu Apple bagi sistem iOS18, iPadOS18 dan macOS Sequoia telah menambah ciri penting pada aplikasi Photos, yang direka untuk membantu pengguna memulihkan foto dan video yang hilang atau rosak dengan mudah disebabkan pelbagai sebab. Ciri baharu ini memperkenalkan album yang dipanggil "Dipulihkan" dalam bahagian Alat pada apl Foto yang akan muncul secara automatik apabila pengguna mempunyai gambar atau video pada peranti mereka yang bukan sebahagian daripada pustaka foto mereka. Kemunculan album "Dipulihkan" menyediakan penyelesaian untuk foto dan video yang hilang akibat kerosakan pangkalan data, aplikasi kamera tidak disimpan ke pustaka foto dengan betul, atau aplikasi pihak ketiga yang menguruskan pustaka foto. Pengguna hanya memerlukan beberapa langkah mudah

Sebagai platform video pendek, Kuaishou membenarkan pengguna berkongsi kehidupan mereka pada bila-bila masa dan di mana-mana sahaja. Peringatan mesej peribadi yang kerap boleh mengganggu kehidupan seharian kita. Jadi, bagaimana untuk mematikan peringatan mesej peribadi Kuaishou? 1. Bagaimana untuk mematikan peringatan mesej peribadi Kuaishou? Untuk mematikan peringatan mesej peribadi Kuaishou, anda perlu memasuki menu tetapan Kuaishou. Pada halaman utama Kuaishou, klik butang "Saya" di penjuru kanan sebelah bawah, cari pilihan "Tetapan" dan klik untuk masuk. Selepas memasuki menu tetapan, semak imbas untuk mencari pilihan "Tetapan Pemberitahuan" atau "Tetapan Mesej" Selepas mengklik untuk masuk, anda akan melihat pilihan "Peringatan Mesej Peribadi". Klik untuk memasukkan peringatan mesej peribadi, dan kemudian matikan suis untuk berhenti menerima peringatan mesej peribadi. 2. Bagaimana untuk menutup mesej pop timbul dalam mesej peribadi Kuaishou? Selain mematikan peringatan mesej peribadi, jika anda juga ingin dapat mematikan peringatan mesej peribadi,

Sebagai salah satu platform video pendek paling popular di dunia, Douyin mempunyai pangkalan pengguna yang besar dan fungsi yang kaya. Fungsi mesej peribadi ialah cara penting untuk pengguna berinteraksi antara satu sama lain, dan nada dering mesej peribadi ialah cara penting untuk mengingatkan pengguna tentang mesej peribadi baharu. Jadi, di manakah saya boleh menetapkan nada dering untuk mesej peribadi TikTok? Artikel ini akan memperkenalkan secara terperinci cara menetapkan nada dering untuk mesej peribadi Douyin dan cara menyelesaikan masalah tiada peringatan bunyi untuk mesej peribadi yang masuk. 1. Di manakah saya boleh menetapkan nada dering untuk mesej peribadi Douyin? 1. Buka apl TikTok: Pertama, buka apl TikTok anda. 2. Masukkan antara muka mesej peribadi: Di bahagian bawah halaman utama Douyin, klik ikon "Mesej" untuk memasuki antara muka mesej peribadi. 3. Buka tetapan: Di penjuru kanan sebelah atas antara muka mesej peribadi, klik ikon tetapan (biasanya bentuk gear). 4. Pilih tetapan mesej peribadi: Dalam menu tetapan, cari dan pilih

HTML tidak boleh membaca pangkalan data secara langsung, tetapi ia boleh dicapai melalui JavaScript dan AJAX. Langkah-langkah termasuk mewujudkan sambungan pangkalan data, menghantar pertanyaan, memproses respons dan mengemas kini halaman. Artikel ini menyediakan contoh praktikal menggunakan JavaScript, AJAX dan PHP untuk membaca data daripada pangkalan data MySQL, menunjukkan cara untuk memaparkan hasil pertanyaan secara dinamik dalam halaman HTML. Contoh ini menggunakan XMLHttpRequest untuk mewujudkan sambungan pangkalan data, menghantar pertanyaan dan memproses respons, dengan itu mengisi data ke dalam elemen halaman dan merealisasikan fungsi HTML membaca pangkalan data.
