Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

एक MySql तालिका के अंदर चैट संदेशों को संग्रहीत करना

आपको एक बेहतर डीबी स्कीमा चाहिए - अधिक संबंधपरक। ऐसा करने से आपको कुछ अन्य सुधार भी मिलेंगे (पासवर्ड से सुरक्षित चैट और जोड़े को नाम देने के लिए बहु-उपयोगकर्ता चैट)

यहां आपके डीबी के लिए एक ईआरडी पर एक टेक दिया गया है।

5/6/2016 संपादित करें (उम्मीद है) बेहतर फ़ील्ड प्रकारों और नामों के साथ डीडीएल जोड़ना

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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. सभी mysql टेबल में एक नया कॉलम जोड़ें

  2. केवल SQL कथन का उपयोग करके वाइल्डकार्ड के साथ mySQL ड्रॉप टेबल?

  3. कैसे डोकर कंटेनर में MySQL डेटा निर्देशिका माइग्रेट करने के लिए?

  4. MySQL दृश्य निश्चित अनुमतियाँ और त्रुटि 1356

  5. एसक्यूएल क्वेरी:बच्चों के बिना माता-पिता बनने के लिए टैग कैसे बनाएं?