Heim Backend-Entwicklung PHP-Tutorial Grundlegendes Funktionsdatenbankdesign für private Nachrichtennachrichten

Grundlegendes Funktionsdatenbankdesign für private Nachrichtennachrichten

Dec 21, 2017 pm 01:33 PM
Datenbank Information private Nachricht

In diesem Artikel wird die Implementierung der Grundfunktionen privater Nachrichten auf Datenbankebene analysiert.

Projektanforderungen: Private Nachrichtenfunktion. Nach dem Senden einer privaten Nachricht an die andere Partei wird die Liste der Personen, die die Nachricht gesendet oder empfangen haben, auf meiner Seite mit der privaten Nachrichtenliste angezeigt Zeigt die neueste Nachricht der Konversation an. Klicken Sie auf ein beliebiges Element in der Liste, um die Detailseite der Nachrichtenkonversation aufzurufen, auf der die Details der Konversation in umgekehrter Reihenfolge angezeigt werden. Gleichzeitig können Sie Konversationen auf diesen beiden Seiten löschen. Die Seite mit der privaten Nachrichtenliste löscht alle Konversationen mit der anderen Partei und die Seite mit den privaten Nachrichtendetails löscht eine bestimmte Konversation. Die Konversationsaufzeichnungen werden einseitig gelöscht, ohne dass dies Auswirkungen auf die Anzeige der anderen Partei hat .

Softwareumgebung: MySQL

Nachdem ich so viel gesagt habe, gibt es in der Tat nur ein paar wichtige Punkte: Erstens zeigt jeder Datensatz in der privaten Nachrichtenliste nur den letzten Datensatz an Zweitens, einseitiges Löschen des Gesprächsprotokolls, ohne die Sichtbarkeit der anderen Partei zu beeinträchtigen. Gehen Sie zuerst zur Datentabelle und erklären Sie sie dann einzeln.

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

Erstellen Sie eine private_Nachrichtentabelle, Feldbeschreibung:

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:删除,标记不同消息状态,可以实现统计未读消息数,逻辑删除用户恢复等

Jeder sollte deprimiert sein, nachdem er das gesehen hat. Wie bekomme ich zwei Absender-IDs und Empfänger-IDs?

Hier gehen wir davon aus, dass das einseitige Löschen von Datensätzen die Anzeigefunktion der anderen Partei nicht beeinträchtigt. Daher müssen wir hier beim Senden einer privaten Nachricht zwei Daten mit demselben Inhalt einfügen, müssen jedoch einige Tricks anwenden Bei Benutzer-ID und Freund-ID werden beim zweimaligen Einfügen von Daten die Benutzer-ID und die Freund-ID der zweiten eingefügten Daten mit den ersten eingefügten Daten vertauscht. Das heißt:

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

Auf diese Weise können unsere Bedürfnisse befriedigt werden. Der erste und vierte Datensatz sind für 121-Benutzer sichtbar, und der zweite und dritte Datensatz sind für 127-Benutzer sichtbar. Wenn 121 den ersten oder vierten Datensatz löscht, hat dies sicherlich keine Auswirkungen auf die Anzeige des zweiten Datensatzes durch 127 ! ! !

Okay, jetzt können Sie sich um andere funktionale Anforderungen kümmern.
1. Meine private Nachrichtenliste

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. Meine privaten Nachrichtenlistenseite

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 🎜>

4. Löschen Sie eine einzelne Konversation aus den Details meiner privaten Nachrichtenliste
UPDATE private_message SETstatus=3 WHERE user_id=121 AND friend_id=1271

5. Erhalten Sie die Anzahl der ungelesenen Nachrichten des Benutzers
UPDATE private_message SET status=3 WHERE id=11

Natürlich Sie Sie können auch ungelesene Nachrichten als gelesen aktualisieren, gelöschte Benutzer aus dem Papierkorb wiederherstellen, Systemnachrichten senden usw. Dies liegt, wie einige Schüler definitiv sagen werden, an der Datenredundanz in diesem Tabellendesign. Jeder Datensatz wird zweimal eingefügt. Wenn viel Inhalt vorhanden ist oder Systemnachrichten gesendet werden, sind die Tabellendaten natürlich nur für Kleine private Nachrichtenfunktionen unterscheiden sich definitiv von großen Social-Networking-Websites, aber wir können den Inhalt auch aufteilen und eine neue Inhaltstabelle erstellen. Hier kann die ID zugeordnet werden, um die Datenredundanz zu reduzieren. Außerdem erfordert dieses Design keinen hohen gleichzeitigen Zugriff! Wenn es um hohe Parallelität geht, sind komplexere Designs und Methoden zur Lösung erforderlich!
SELECT COUNT(*) FROM private_message WHERE user_id=121 AND receiver_id=127 AND status=11


Verwandte Lektüre:

PHP-Chat-Eins-zu-Eins-Chat-Funktionsquellcode

Wie lässt sich der Einsatz von Datenbankindizes effizienter gestalten?

Allgemeine Schritte und Beispiele zum Entwerfen einer DatenbankDas Obige ist der gesamte Inhalt dieses Artikels Wenn Sie Fragen haben, können Sie uns gerne kontaktieren. Hinterlassen Sie eine Nachricht im Kommentarbereich!

Das obige ist der detaillierte Inhalt vonGrundlegendes Funktionsdatenbankdesign für private Nachrichtennachrichten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

PHP-Tutorial
1510
276
iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen Jul 18, 2024 am 05:48 AM

Apples neueste Versionen der iOS18-, iPadOS18- und macOS Sequoia-Systeme haben der Fotoanwendung eine wichtige Funktion hinzugefügt, die Benutzern dabei helfen soll, aus verschiedenen Gründen verlorene oder beschädigte Fotos und Videos einfach wiederherzustellen. Mit der neuen Funktion wird im Abschnitt „Extras“ der Fotos-App ein Album mit dem Namen „Wiederhergestellt“ eingeführt, das automatisch angezeigt wird, wenn ein Benutzer Bilder oder Videos auf seinem Gerät hat, die nicht Teil seiner Fotobibliothek sind. Das Aufkommen des Albums „Wiederhergestellt“ bietet eine Lösung für Fotos und Videos, die aufgrund einer Datenbankbeschädigung verloren gehen, die Kameraanwendung nicht korrekt in der Fotobibliothek speichert oder eine Drittanbieteranwendung die Fotobibliothek verwaltet. Benutzer benötigen nur wenige einfache Schritte

Wie speichere ich JSON-Daten in einer Datenbank in Golang? Wie speichere ich JSON-Daten in einer Datenbank in Golang? Jun 06, 2024 am 11:24 AM

JSON-Daten können mithilfe der gjson-Bibliothek oder der json.Unmarshal-Funktion in einer MySQL-Datenbank gespeichert werden. Die gjson-Bibliothek bietet praktische Methoden zum Parsen von JSON-Feldern, und die Funktion json.Unmarshal erfordert einen Zieltypzeiger zum Unmarshalieren von JSON-Daten. Bei beiden Methoden müssen SQL-Anweisungen vorbereitet und Einfügevorgänge ausgeführt werden, um die Daten in der Datenbank beizubehalten.

MySQL: Einfache Konzepte für einfaches Lernen MySQL: Einfache Konzepte für einfaches Lernen Apr 10, 2025 am 09:29 AM

MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

Orakels Rolle in der Geschäftswelt Orakels Rolle in der Geschäftswelt Apr 23, 2025 am 12:01 AM

Oracle ist nicht nur ein Datenbankunternehmen, sondern auch ein führender Anbieter von Cloud -Computing- und ERP -Systemen. 1. Oracle bietet umfassende Lösungen von der Datenbank bis zu Cloud -Diensten und ERP -Systemen. 2. Oraclecloud fordert AWS und Azure heraus und liefert IaaS-, PaaS- und SaaS -Dienste. 3. ERP-Systeme von Oracle wie E-Businesssuite und Fusion Applications helfen Unternehmen dabei, den Betrieb zu optimieren.

MySQL: Eine Einführung in die beliebteste Datenbank der Welt MySQL: Eine Einführung in die beliebteste Datenbank der Welt Apr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

MySQL gegen andere Datenbanken: Vergleich der Optionen MySQL gegen andere Datenbanken: Vergleich der Optionen Apr 15, 2025 am 12:08 AM

MySQL eignet sich für Webanwendungen und Content -Management -Systeme und ist beliebt für Open Source, hohe Leistung und Benutzerfreundlichkeit. 1) Im Vergleich zu Postgresql führt MySQL in einfachen Abfragen und hohen gleichzeitigen Lesevorgängen besser ab. 2) Im Vergleich zu Oracle ist MySQL aufgrund seiner Open Source und niedrigen Kosten bei kleinen und mittleren Unternehmen beliebter. 3) Im Vergleich zu Microsoft SQL Server eignet sich MySQL besser für plattformübergreifende Anwendungen. 4) Im Gegensatz zu MongoDB eignet sich MySQL besser für strukturierte Daten und Transaktionsverarbeitung.

MySQL: Ein anfängerfreundlicher Ansatz zur Datenspeicherung MySQL: Ein anfängerfreundlicher Ansatz zur Datenspeicherung Apr 17, 2025 am 12:21 AM

MySQL ist für Anfänger geeignet, da es einfach zu bedienen und leistungsfähig ist. 1.Mysql ist eine relationale Datenbank und verwendet SQL für CRUD -Operationen. 2. Es ist einfach zu installieren und erfordert, dass das Stammbenutzerkennwort konfiguriert wird. 3.. Verwenden Sie Einfügen, Aktualisieren, Löschen und Wählen Sie, um Datenvorgänge auszuführen. 4. OrderBy, wo und Join kann für komplexe Abfragen verwendet werden. 5. Debugging erfordert die Überprüfung der Syntax und verwenden Sie Erklärungen zur Analyse der Abfrage. 6. Die Optimierungsvorschläge umfassen die Verwendung von Indizes, die Auswahl des richtigen Datentyps und der guten Programmiergewohnheiten.

Warum MySQL verwenden? Vorteile und Vorteile Warum MySQL verwenden? Vorteile und Vorteile Apr 12, 2025 am 12:17 AM

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

See all articles