<?php
defined('ACC')||exit('Access denied');class userModel {
    protected $table = 'user';
    protected $db = false;    public function __construct() {
        $this->db = mysql::getIns();
    }    // 用户注册的方法
    public function reg($arr) {
        $sql = "insert into ". $this->table . "(username,passwd,email) values ('" . $arr['username'] . "','" . $arr['passwd'] . "','" . $arr['email'] . "')";
      
       return $this->db->query($sql);
       //print_r(mysql_error());
    }
}
那个sql语句里单双引号无论怎么看都不理解,忘朋友解疑!!!!!!!

解决方案 »

  1.   

    如果这样写你是否能理解?
    $sql = "insert into $this->table (username,passwd,email) values (' $arr[username]','$arr[passwd]','$arr[email]')";
      

  2.   

    你给的sql中  双引号是php的字符串定义符 ,单引号是sql字符串定义符
      

  3.   

    有点明白了,是不是可以这样理解第一部分:$sql = "insert into ".$this->table."(username,password,email) values ('')";
    第二部分:$sql = "insert into ".$this->table."(username,password,email) values ('".$arr['username']."','".$arr['password']."','".$arr['email']."')";
      

  4.   


    以后直接echo $SQL 然后再仔细看就能明白.