donglisi8644 2013-02-02 17:25
浏览 6
已采纳

将查询数据传递给方法的正确方法?

I have a User class and I'm wondering what would be the "most recommended" way to handle insertions?

Option 1: Use an existing object

// insert a new user and return the user id
public function insert() {
    $sql = "INSERT INTO users (username, password, email, avatar, subscribe, created, last_login, valid) VALUES
                              (?, ?, ?, ?, ?, ?, ?, ?)";
    $sth = $this->db->prepare($sql);
    $sth->bindParam(1, $this->username, PDO::PARAM_STR);
    $sth->bindParam(2, $this->password, PDO::PARAM_STR);
    $sth->bindParam(3, $this->email, PDO::PARAM_STR);
    $sth->bindParam(4, $this->avatar, PDO::PARAM_STR);
    $sth->bindParam(5, $this->subscribe, PDO::PARAM_STR);
    $sth->bindParam(6, $this->created, PDO::PARAM_STR);
    $sth->bindParam(7, $this->last_login, PDO::PARAM_STR);
    $sth->bindParam(8, $this->valid, PDO::PARAM_STR);
    $sth->execute();

    return $this->db->lastInsertId();
}

Option 2: Pass the information in as an array

// insert a new user and return the user id
public function insert(array $fields = array()) {
    if(!empty($fields)) {
        $sql = "INSERT INTO users (username, password, email, avatar, subscribe, created, last_login, valid) VALUES
                                  (:username, :password, :email, :avatar, :subscribe, :created, :last_login, :valid)";
        $sth = $this->db->prepare($sql);
        $sth->execute($fields);

        return $this->db->lastInsertId();
    }
}

Another option? Does it make any difference?

  • 写回答

1条回答 默认 最新

  • drv54591 2013-02-02 17:28
    关注

    Both ways are okay but personally I suggest second option

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算