【问题标题】:PHP+Ajax : Add-a-friend systemPHP+Ajax : 加好友系统
【发布时间】:2011-04-29 12:52:34
【问题描述】:

我正在尝试做一个小项目来添加朋友。 当您单击添加好友按钮时,您正在向 add.php 文件发送一个带有好友 ID 和用户名(它们是每个添加按钮的 ID 和名称属性)的 Ajax 调用。 (mysql结构为:1个users表+X个以用户名命名的表(columns:friendid,ispending)) 在 PHP 文件中只有 2 个 MySQLi 查询:这是添加文件的代码:

session_start();
$friendid = $_POST['id'];
$myname = $_SESSION['username'];
$friendname = $_POST['name'];
$myid = $_SESSION['id'];
$add = new Mysqlconnect();
$add->db->query("INSERT INTO $myname VALUES($friendid, 'yes')");
$add->db->query("INSERT INTO $friendname VALUES ($myid, 'yes')");
$add->db_Close();

Mysqlconnect 类是必需的,我只是不希望这里的代码太长。 这是 Ajax 调用:

$('.add').click(function(){
 var name = $(this).attr("name");
 var id = $(this).attr("id");
   $.ajax({
      type: "POST",
      data: "&name="+name+"&id="+id,
      url: 'add.php',
      success: function(){
         alert("success");
      }
   });
});

问题: 当我单击“添加朋友”时,它确实会提示“成功”,但每次只有一个表更新,甚至根本没有表。 虽然有一次我点击它并且它确实有效(那次我没有更改代码,我尝试每 20 秒点击一次)。

我该如何解决这个问题?

【问题讨论】:

  • 首先,您应该转义 $_POST 值...
  • 您的所有用户似乎都有一个单独的表...(“INSERT INTO $myname VALUES”)...为什么要使用它。建立关系会更好
  • 这样可以解决问题吗?如果我这样做,ajax 调用会一直工作吗?

标签: php mysql ajax mysqli friend


【解决方案1】:

如果我对您的理解正确,您似乎正在为每个用户的朋友创建一个新表(1 个用户表 + X 个以用户名命名的表),这不是一个好方法,您最好只使用 2 个表:用户和 user_friends 如下:

drop table if exists users;
create table users
(
user_id int unsigned not null auto_increment primary key,
username varbinary(32) unique not null
)
engine=innodb;

drop table if exists user_friends;
create table user_friends
(
user_id int unsigned not null,
friend_user_id int unsigned not null,
created_date datetime not null,
primary key (user_id, friend_user_id) -- note clustered composite PK (innodb only)
)
engine=innodb;

可以在此处找到完整的示例脚本:http://pastie.org/1242699

希望这会有所帮助。

【讨论】:

  • 如果我这样做,记录会翻倍,不是吗?比如: 5 和 10 是朋友,10 是 5 的朋友。有没有办法防止这种情况发生或者就这样保持下去?
  • 为什么要阻止它,用户 5 是否有可能删除他与 10 的友谊链接,因为也许他们不再经常聊天,但用户 10 决定保持与 5 的友谊关系。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-08-16
  • 2011-10-31
  • 2013-04-28
  • 2011-08-30
  • 2020-09-01
  • 2020-09-01
  • 2017-03-24
相关资源
最近更新 更多