关于php中mysql mysqli 区别
升级了php7,发现有一堆东西用不了。这是原来的代码:classlrdb{public$conn;public$debug=false;publicfunction__c...
升级了php7,发现有一堆东西用不了。
这是原来的代码:
class lrdb{
public $conn;
public $debug=false;
public function __construct($s,$u,$p,$d){
$this->conn=mysql_connect($s,$u,$p) or die('connect database fail');
mysql_query($this->conn,"set names 'utf8'");
mysql_select_db($this->conn,$d);
}
public function __destruct(){
mysql_close($this->conn);
}
public function getid(){
return mysql_insert_id($this->conn);
}
public function affect(){
return mysql_affected_rows($this->conn);
}
public function query($t){
$res=mysql_query($this->conn,$t);
while(@$r=mysql_fetch_array($this->conn,$res)){
if($r)@$row[]=$r;
}
if($this->debug){
echo $t."<br>\n";
$err=mysql_error($this->conn);
if($err){
echo $err;
echo "<br>\n";
}
}
if(isset($row))
return $row;
else
return NULL;
}
public function filter($t){
return mysql_real_escape_string($this->conn,$t);
}
}
修改成了下面的样子,还是用不了
class lrdb{
public $conn;
public $debug=false;
public function __construct($s,$u,$p,$d){
$this->conn=mysqli_connect($s,$u,$p) or die('connect database fail');
mysqli_query($this->conn,"set names 'utf8'");
mysqli_select_db($this->conn,$d);
}
public function __destruct(){
mysqli_close($this->conn);
}
public function getid(){
return mysqli_insert_id($this->conn);
}
public function affect(){
return mysqli_affected_rows($this->conn);
}
public function query($t){
$res=mysqli_query($this->conn,$t);
while(@$r=mysqli_fetch_array($this->conn,$res)){
if($r)@$row[]=$r;
}
if($this->debug){
echo $t."<br>\n";
$err=mysqli_error($this->conn);
if($err){
echo $err;
echo "<br>\n";
}
}
if(isset($row))
return $row;
else
return NULL;
}
public function filter($t){
return mysqli_real_escape_string($this->conn,$t);
}
}
if(isset($row))
return $row;
else
return NULL;
这一句也是后来加上去的,不知道是不是跟它有关 展开
这是原来的代码:
class lrdb{
public $conn;
public $debug=false;
public function __construct($s,$u,$p,$d){
$this->conn=mysql_connect($s,$u,$p) or die('connect database fail');
mysql_query($this->conn,"set names 'utf8'");
mysql_select_db($this->conn,$d);
}
public function __destruct(){
mysql_close($this->conn);
}
public function getid(){
return mysql_insert_id($this->conn);
}
public function affect(){
return mysql_affected_rows($this->conn);
}
public function query($t){
$res=mysql_query($this->conn,$t);
while(@$r=mysql_fetch_array($this->conn,$res)){
if($r)@$row[]=$r;
}
if($this->debug){
echo $t."<br>\n";
$err=mysql_error($this->conn);
if($err){
echo $err;
echo "<br>\n";
}
}
if(isset($row))
return $row;
else
return NULL;
}
public function filter($t){
return mysql_real_escape_string($this->conn,$t);
}
}
修改成了下面的样子,还是用不了
class lrdb{
public $conn;
public $debug=false;
public function __construct($s,$u,$p,$d){
$this->conn=mysqli_connect($s,$u,$p) or die('connect database fail');
mysqli_query($this->conn,"set names 'utf8'");
mysqli_select_db($this->conn,$d);
}
public function __destruct(){
mysqli_close($this->conn);
}
public function getid(){
return mysqli_insert_id($this->conn);
}
public function affect(){
return mysqli_affected_rows($this->conn);
}
public function query($t){
$res=mysqli_query($this->conn,$t);
while(@$r=mysqli_fetch_array($this->conn,$res)){
if($r)@$row[]=$r;
}
if($this->debug){
echo $t."<br>\n";
$err=mysqli_error($this->conn);
if($err){
echo $err;
echo "<br>\n";
}
}
if(isset($row))
return $row;
else
return NULL;
}
public function filter($t){
return mysqli_real_escape_string($this->conn,$t);
}
}
if(isset($row))
return $row;
else
return NULL;
这一句也是后来加上去的,不知道是不是跟它有关 展开
2个回答
展开全部
PHP中mysql有两个概念,一个是mysql数据库,一个是用于操作mysql数据库的扩展(PHP的各种功能都是通过这些底层扩展来实现的)。而你这个问题中的mysql,就指的是扩展。
PHP5开始有了mysqli,按照PHP官方描述,它是mysql增强版扩展。事实上它确实更搞笑更安全,并推荐大家使用。到PHP5.3的时候,原来的mysql扩展已经被标注为过时。而到了PHP7,原mysql扩展被彻底废弃。
所以不管是否使用PHP7,都建议使用mysqli或pdo扩展来操作mysql数据库。
另外,mysqli并不是简单的在原来mysql的方法上加一个i,它是自己一套方法。mysqli同时支持面向过程和面向对象的方式,强烈建议你学者使用面向对象的方式。
PHP5开始有了mysqli,按照PHP官方描述,它是mysql增强版扩展。事实上它确实更搞笑更安全,并推荐大家使用。到PHP5.3的时候,原来的mysql扩展已经被标注为过时。而到了PHP7,原mysql扩展被彻底废弃。
所以不管是否使用PHP7,都建议使用mysqli或pdo扩展来操作mysql数据库。
另外,mysqli并不是简单的在原来mysql的方法上加一个i,它是自己一套方法。mysqli同时支持面向过程和面向对象的方式,强烈建议你学者使用面向对象的方式。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不能用,你看报什么错误我就知道了吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询