这要从一个故事说起。 某一天,一位名叫MySQL的农夫的一把斧子(数据库操作)掉进了一条名为PHP的河里,这时候,一位好心的河神出现了
PHP河的河神问他。。。。
下面,咱们还是说正经的把!。。。(:3 」∠)
在我主机(localhost)的penghuwan数据库下,有张mytable的表如下图所示
PHP针对mysql数据库的操作有两套接口:面向对象接口和面向过程接口;
因为执行写改删操作的PHP语句类似,所以这里只以“写操作”和“查操作”为例子
connect_error){//当有连接错误的时候,结束脚本运行并且报错
die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)
}
$query = "SELECT * FROM mytable";//把一段SQL语句保存在$query变量中
$mysqli_result = $mysqli->query($query);//通过调用上面返回的mysqli对象中的方法,返回一个结果集对象(mysqli_result)
while($row = $mysqli_result->fetch_assoc()){//调用mysqli_result的方法fetch_assoc()后,返回的是一个数组变量$row
echo $row['name'];//访问返回数组变量$row中的数组成员,对应mytable表中的name列
echo $row['number'];;//访问返回数组变量$row中的数组成员,对应mytable表中的number
echo "
";
}
$mysqli_result->free();//释放结果集
$mysqli ->close();//关闭数据库连接
?>
复制
首先通过
new mysqli($host, $username, $passwd, $dbname)
复制
获取一个mysqli对象,然后在下面我们就可以通过调用对象中的方法query方法去实现写改删查
运行结果:
思维导图
上面的例子中,一个关键的方法是mysqli对象的query方法,意为查询.但实际上,它除了能运行“查”的SQL语句外,还能运行“写改删”的SQL语句。
关于query的返回值:
";
}
mysqli_free_result($mysqli_result);//释放结果集
mysqli_close($mysqli);//关闭数据库连接
?>
复制
【注意点】
拥有两套接口固然增加了记忆难度,但如果你注意观察的话,两套接口函数的名称是联系紧密的。
connect_error){//当有连接错误的时候,结束脚本运行并且报错
die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)
}
$query = "INSERT INTO mytable VALUES('C',30)";//把一段SQL语句保存在$query变量中
$mysqli->query($query);// 此时返回的不是结果集对象,而是一个boolean,代表成功或失败
$mysqli ->close();//关闭数据库连接
?>
复制
运行结果:
思维导图
和第一个“查”的例子类似,这里不多加赘述。
在实际操作中,我们可能需要处理大量相同类型的不同SQL语句,例如
"SELECT * FROM mytable WHERE name = ‘A’"
复制
或者
"SELECT * FROM mytable WHERE name = ‘B’"
复制
这样的语句。你可能会试图自己封装函数来避免写一大堆相同类型的语句。但实际上,PHP已经给我们封装好了一系列的内置函数,它就是prepare语句:
我们接下来实现这样一段PHP脚本: 通过prepare语句给mytable插入两行数据(类型相同的不同SQL语句)
我们原来的mytable表长这样:
我们下面向其中插入两行
列1 |
列2 |
---|---|
D |
40 |
E |
50 |
connect_error){//当有连接错误的时候,结束脚本运行并且报错
die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)
}
$query = "INSERT INTO mytable VALUES(?,?)";//,“?”表示模板中要被实际替换的变量
$stmt = $mysqli->prepare($query);//通过prepare函数生成mysqli_statement对象
$name1 = 'D';
$number1 = 40;
$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$stmt->execute();//第一次执行
$name2 = 'E';
$number2 = 50;
$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$stmt->execute();//第二次执行
$stmt->close();//关闭mysqli_statement
$mysqli ->close();//关闭数据库连接
?>
复制
思维导图
运行结束后:
关键的一个方法是bind_param()方法,它接受多个参数,其中 第一个参数代表后面参数的类型。
第一个参数是一个字符串,由固定顺序的字符组成,这些字符包括“s”,”i”,”d”,”b”,分别表示字符串,整型,双精度和二进制文本,依次代表后面参数的类型。
字符 |
代表类型 |
---|---|
“s” |
字符串 |
“i” |
整型 |
“d” |
双精度 |
“b” |
二进制文本 |
例如:我们上面的$stmt->bind_param("si",$name1,$number1);代表:$name1是字符串类型,,$number1是整型
【注意】
bind_param("si",$name1,$number1);
?>
复制
改成:
bind_param("si",'D',40);
?>
复制
运行:
【注意】
例如我们把上面的
$name1 = 'D';
$number1 = 40;
$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$stmt->execute();//第一次执行
$name2 = 'E';
$number2 = 50;
$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$stmt->execute();//第二次执行
复制
改成:
$name1 = 'D';
$number1 = 40;
$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$name2 = 'E';
$number2 = 50;
$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"
$stmt->execute();//第二次执行
复制
运行结果:
它并不会批量执行$name1,$number1和$name2,$number2的插入,而是只插入了$name2,$number2,因为最后一个bind_param()覆盖前面写的的 bind_param()
上面的例子中我们演示了如何绑定参数,下面我来演示如何绑定结果,这里将用到bind_result()函数:
connect_error){//当有连接错误的时候,结束脚本运行并且报错
die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)
}
$query = "SELECT * FROM mytable";//prepare函数的参数
$stmt = $mysqli->prepare($query);//通过prepare函数生成mysqli_statement对象
$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中
$stmt->execute();// 执行生成查询结果
while($stmt->fetch()){// 将查询结果中的第一行的列值分别赋给$name和,$number,同时游标移到下一行
echo $name.' '.$number;//输出mytable中当前行各个列的列值
echo "
";
}
$stmt->close();//关闭mysqli_statement
$mysqli ->close();//关闭数据库连接
?>
复制
思维导图
运行结果如下:
【注意】
$stmt->execute();// 执行生成查询结果
$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中
复制
运行结果同上(但注意bind_result应放在fetch语句前)
$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中
$stmt->execute();// 执行生成查询结果
echo 'execute执行后$name的值为';
var_dump($name);
复制
运行结果:
$query1 = "SELECT name FROM mytable";
$stmt = $mysqli->prepare($query1);
$stmt->execute();//执行第一个prepare模板语句
$query2 = "SELECT number FROM mytable";//prepare函数的参数
$stmt = $mysqli->prepare($query2);
$stmt->execute();//执行第二个prepare模板语句 [注],这就是24行
复制
提示的错误是,我对一个boolean值调用了execute函数 我尝试输出$stmt(最下面那个),输出为false(这里不做展示了) 这说明执行第二个prepare模板语句的时候失败了,那这时候该怎么办呢?
让我们在两段prepare模板语句间加上
$stmt->close():
复制
即:
prepare($query1);
$stmt->execute();//执行第一个prepare模板语句
$stmt->close();
$query2 = "SELECT number FROM mytable";//prepare函数的参数
$stmt = $mysqli->prepare($query2);
$stmt->execute();//执行第二个prepare模板语句
?>
复制
运行:报错消失
应该注意的是三个方面的事情:
";
echo '重新取出值'.stripslashes($text);
?>
复制
输入空值的时候:
输入带空格和魔术字符串的文本——“【空格】penghuwan”