留言板完整的数据库用Access怎么设计

留言板完整的数据库用Access怎么设计,第1张

1.个人资料基本表(USER):

USER_ID(用户ID)

USER_NAME(用户名称)

USER_QNAME(访客昵称)

USER_SEX(性别)

USER_IMG(头像)

USER_MAIL(邮箱地址)

USER_TEL(电话)

USER_MOBILE(移动电话)

USER_INTRODUCE(个人介绍)

USER_ADDR(用户地址)

USER_PASS(用户密码)

USER_Sts(用户状态)

USER_Bith_Date(用户生日)

USER_LOGINTIME(灯录时间)

USER_LOGINNO(灯灵次数)

USER_OUTLINE(下线时间)

USER_REGITIME(注册时间)

USER_IP(IP)

USER_Accum(积分)

USER_Crdblty(信用度)

USER_DENGJI(用户等级)

这是个基本表,但是却是个很重要的表,因为接下来的表都是要跟他相关联的.

2.权限表(user_role)

r_id(权限ID)

r_userid(与用户表的ID相关联)

r_name(权限名称)

r_dsc(权限描述)

2.回帖和留言可以放在一起(USER_MESSAGE)

M_ID(信息ID)

M_USERID(与用户表的ID相关联)

M_time(留言时间)

m_updatetiem(留言修改时间)

m_name(留言主题)

m_dsc(留言内容

m_model(留言模式)

m_rid(权限ID,与权限表相关联)

显示头像,需要在前台做处理

select 用户头像 from user where ....

就好啦,如果有疑问,请留下QQ

留言表:

Id int not null 主键 自动增长列 留言Id

userId int not null 留言给的用户 建立于用户表的外键约束(如果用户表中没有某一用户Id 则不允许插入改Id)

usersid int not null 提交留言的用户的Id 建立于用户表的外键约束(如果用户表中没有某一用户Id 则不允许插入改Id)

words text not null 留言内容

回复表

Replay:

Id int not null 主键 自动增长列 留言回复 Id

liuyanId int not null 该回复是回复的哪条留言 建立于留言表的外键约束(如果留言表中没有这条留言货已经删除 则不允许插入改Id)

words text not null 回复的内容

上面是数据库的结构图

 id                        这个算是父Id 可以通过这个id来查询 在这个id下是否有子id 同时也可以记录这个是那条留言的id

son_id                    这个是子id 然后通过这个id 可以找到相对应的父id

   news_id                   记录文章的id 

   sender_author             接受留言的人

   receiver_author           发送留言的人

   content                   留言的内容

   status                    在有人回复你的帖子的时候 这个值从0转为1时候 该消息不在显示 如果没点击进去 该消息依然存在

   time                      记录留言的时间

留言板回复思路

当发送方(也就留言的人)要到该文章下留言或者回复的的时候就需要接收方(也就文章的作者或者要被回复的人)来接收。单数据库语句查询到这个键sender_author和receiver_author 的是就会知道接收方是谁和发送方是谁了。然后在根据这个判断来显示出回复内容

提示你有一条新的消息思路

当发送方发送消息的时候 这个status的值默认为0 就是提示接收发 你有一条新的消息。当点击进去的时候 调用数据库修改语句把指定的值修改成为1 这样就不显示了

查看评论的时候 的数据库 *** 作语句

代码如下:

function message($id){    

  $query = $this->db->query("SELECT * FROM message WHERE news_id = '$id'")//或者文章id后查询里面所有评论   

  return $query->result()    

 }

这个是获取父的留言内容的代码

代码如下:

<?php foreach($query as $sel){?>

<p>留言用户:<?php echo $sel->receiver_author?>留言内容:<?php echo $sel->content?></p>

<?php }?>

用户是否登陆 并给予留言权限

代码如下:

<form id="form1" name="form1" method="post" action="<?php echo site_url()."/publish/user_message"?>">

<textarea rows="5" cols="50" name="huifu" <?php if($uere_name == "0"){echo "disabled"}?>>

<?php

 if($uere_name == "0")

{echo "抱歉你还没登录不能进行留言"}

?>

</textarea>

<input class="wole" name="author" value="<?php echo $author?>" /><!--接受方帖子作者-->

<input class="wole" name="news_id" value="<?php echo $news_idx?>" /><!--文章id-->

<input type="submit" name="Submit"/>

</form>

<script language="javascript">

function updateinfo(){

  if(<?php echo $uere_name?>== 1){

    document.form1.Submit.value = "留言"

    document.form1.Submit.disabled = false

  }

  else{

    document.form1.Submit.value = "还未登录"

 document.form1.Submit.disabled = "disabled"

  }

}

updateinfo()

</script>

这个是显示了 获取指定的父id 之后来显示他里面的全部子id 和留言内容

代码如下:

<p>这里是<?php echo $is?>楼 用户:<?php echo $sel->receiver_author?><br />留言内容:<?php echo $sel->content?>

<a onClick="showdiv('contentid<?php echo $is?>','showtext<?php echo $is?>')" href="javascript:void(0)">回复</a>

<div id="contentid<?php echo $is?>" class="none">

<?php  

 $query = $this->db->query("select * from message where son_id ='$sel->id' order by id")//获取指定父id的子回复

 $revis = $query->result()

    foreach($revis as $row){?>

 <p><?php if($row->sender_author == $row->receiver_author){echo $row->sender_author} 

 else{ echo $row->sender_author."回复了:".$row->receiver_author}?>

  内容是:<?php echo $row->content?></p>

<?php }?>

<form action="<?php echo site_url()."/publish/son_message"?>" method="post">

<input name="son_idx" class="wole" value="<?php echo $sel->id?>" />

<input name="receiver_author" class="wole" value="<?php echo $sel->receiver_author?>" />

<input class="wole" name="news_id" value="<?php echo $news_idx?>" /><!--文章id-->

<textarea rows="5" cols="50" name="huifux"></textarea>

<br><input type="submit" name="sub" value="回复"></form></div></p>

<script language="JavaScript" type="text/JavaScript">

<!--

function showdiv(targetid,objN){

      var target=document.getElementById(targetid)

      var clicktext=document.getElementById(objN)

            if (target.style.display=="block"){

                target.style.display="none"

                clicktext.innerText="回复"

} else {

                target.style.display="block"

                clicktext.innerText='收起'

            }

}

-->

</script>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6460244.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-22
下一篇 2023-03-22

发表评论

登录后才能评论

评论列表(0条)

保存