sql >> Databasteknik >  >> RDS >> Mysql

Lagra chattmeddelanden i en MySql-tabell

Du behöver ett bättre db-schema - mer relationellt. Om du gör det kommer du också att få några andra förbättringar (lösenordsskyddade chattar och fleranvändarchatt för att nämna ett par)

Här är en version av en ERD för din db.

5/6/2016 editLägger till DDL med (förhoppningsvis) förbättrade fälttyper och namn

CREATE TABLE user
(
    user_id CHAR(32),
    user_login VARCHAR(255),
    user_password CHAR(64),
    user_email VARCHAR(400),
    PRIMARY KEY (user_id)
);

CREATE TABLE message
(
    message_id CHAR(32),
    message_datetime DATETIME,
    message_text TEXT,
    message_chat_id CHAR(32),
    message_user_id CHAR(32),
    PRIMARY KEY (message_id)
);

CREATE TABLE user_chat
(
    user_chat_chat_id CHAR(32),
    user_chat_user_id CHAR(32),
    PRIMARY KEY (user_chat_chat_id,user_chat_user_id)
);

CREATE TABLE chat
(
    chat_id CHAR(32),
    chat_topic VARCHAR(32),
    chat_password CHAR(64),
    user_chat_user_id CHAR(32),
    PRIMARY KEY (chat_id)
);

CREATE INDEX user_login_idx ON user (user_login);
ALTER TABLE message ADD FOREIGN KEY message_chat_id_idxfk (message_chat_id) REFERENCES chat (chat_id);

ALTER TABLE message ADD FOREIGN KEY message_user_id_idxfk (message_user_id) REFERENCES user (user_id);

ALTER TABLE user_chat ADD FOREIGN KEY user_chat_user_id_idxfk (user_chat_user_id) REFERENCES user (user_id);

ALTER TABLE chat ADD FOREIGN KEY chat_id_idxfk (chat_id,user_chat_user_id) REFERENCES user_chat (user_chat_chat_id,user_chat_user_id);


  1. Säker metod för att lagra/hämta en privat PGP-nyckel och lösenordsfras?

  2. En guide till automatiserade molndatabaser

  3. Hur man gör ett urval med array innehåller värdesats i psql

  4. PDO-stöd för flera frågor (PDO_MYSQL, PDO_MYSQLND)