我正在实现没有任何软件包的简单私人消息传递应用程序。
消息表包含以下列 id,from_id,to_id,message,created_at
我希望用户能够显示以下示例中的消息 -
User1:嗨 User2:您好
用户1:你好吗? User1:怎么回事? User2:好的。
答案 0 :(得分:0)
创建两个表 Conversations 和 Messages 使用用户之间的session_id(如果存在),然后添加消息,并使用user_id将发送消息的人存储在messages表中。
class CreateMessagesTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('messages', function (Blueprint $table) {
$table->increments('id');
$table->text('message');
$table->boolean('is_seen')->default(0);
$table->boolean('deleted_from_sender')->default(0);
$table->boolean('deleted_from_receiver')->default(0);
$table->integer('user_id');
$table->integer('conversation_id');
$table->timestamps();
});
}
class CreateConversationsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('conversations', function (Blueprint $table) {
$table->increments('id');
$table->integer('user_one');
$table->integer('user_two');
$table->boolean('status')->default(1);
$table->timestamps();
});
}
答案 1 :(得分:-1)
它的many to many关系。您应该创建数据透视表,其中两个键指向id
表中的users
:
Schema::create('messages_pivot', function (Blueprint $table) {
$table->increments('id');
$table->integer('from_id')->unsigned();
$table->integer('to_id')->unsigned();
$table->string('message');
$table->timestamps();
});
Schema::table('messages_pivot', function (Blueprint $table) {
$table->foreign('from_id')->references('id')->on('users')->onDelete('cascade');
$table->foreign('to_id')->references('id')->on('users')->onDelete('cascade');
});
您可以使用relations来使用此数据透视表,也可以为其创建模型。