PHP与MySQL交互
<?php $con = mysql_connect("localhost","root","12345"); $dbcharset = "utf8"; mysql_query("SET character_set_connection=$dbcharset, character_set_results=$dbcharset, character_set_client=binary"); if (!$con) { die('Could not connect: ' . mysql_error()); } // some code mysql_select_db("my_db", $con); ?>
1.php连接数据库
$mysqli = mysqli_connect("hostname", "username", "password", "database");
<?php $mysqli = mysqli_connect("localhost", "root", "12345", "test"); //错误信息 if(mysqli_connect_errno()) { //错误信息 printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } else { //输出Host信息 printf("Host infomation: %s\n", mysqli_get_host_info($mysqli)); //显示关闭连接 mysqli_close($mysqli); } ?>
旧版使用mysql函数集
2.查询
<?php $mysqli = mysqli_connect("localhost", "root", "12345", "test"); //错误信息 if(mysqli_connect_errno()) { //错误信息 printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } else { $sql = "CREATE TABLE testTable (id INT NOT NULL PRIMARY KEY AUTO_INCREMENT, testField VARCHAR(75))"; $res = mysqli_query($mysqli, $sql); if($res === TRUE) { echo "Table testTable successfully created."; } else { //获取MYSQL错误信息 printf("Could not create table: %s\n", mysqli_error($mysqli)); } //显示关闭连接 mysqli_close($mysqli); } ?>
mysqli_error($mysqli)可以获取错误信息
3.mysqli_query使用Mysql数据
3.1避免SQL注入
在一个登陆过程中,查询过程大概如下
SELECT * FROM users WHERE name = '".$_POST['username']."';
假设username的值为 ' or '1' = '1
这会产生一个完整的查询如
SELECT * FROM users Where name = ' ' or '1' = 1;
这个查询结果总是为真。 这就是sql注入。
要避免注入就要限制用户的输入,比如特殊字符(and, or)等都禁止提交。
3.2插入数据
插入表单中的数据
表单提交页面
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>
<form method="post" action="insert.php" >
<input type="text" name='testfield' />
<input type="submit" />
</form>
<body>
</body>
</html>
处理页面insert.php
<?php $mysqli = mysqli_connect("localhost", "root", "12345", "test"); //错误信息 if(mysqli_connect_errno()) { //错误信息 printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } else { // 超全局变量$_POST访问表单 $clean_text = mysqli_real_escape_string($mysqli, $_POST['testfield']); $sql = "INSERT INTO testTable (testField) VALUES ('".$clean_text."')"; $res = mysqli_query($mysqli, $sql); if($res === TRUE) { echo "插入数据成功"; } else { //获取MYSQL错误信息 printf("插入数据失败: %s\n", mysqli_error($mysqli)); } //显示关闭连接 mysqli_close($mysqli); } ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> </head> <body> </body> </html>
3.3php获取数据
3.31查询结果个数
<?php $mysqli = mysqli_connect("localhost", "root", "12345", "test"); //错误信息 if(mysqli_connect_errno()) { //错误信息 printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } else { $sql = "SELECT * FROM testTable"; $res = mysqli_query($mysqli, $sql); if($res) { //mysqli_num_rows获取结果个数 $number_of_rows = mysqli_num_rows($res); printf("拥有%s组结果:", $number_of_rows); } else { //获取MYSQL错误信息 printf("查询失败: %s\n", mysqli_error($mysqli)); } //mysqli_free_result释放结果内存供其它脚本使用 mysqli_free_result($res); //显示关闭连接 mysqli_close($mysqli); } ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> </head> <body> </body> </html>
mysqli_free_result释放结果内存供其它脚本使用,mysqli_num_rows获取结果个数
3.32显示查询结果
<?php $mysqli = mysqli_connect("localhost", "root", "12345", "test"); //错误信息 if(mysqli_connect_errno()) { //错误信息 printf("Connect failed: %s\n", mysqli_connect_error()); exit(); } else { $sql = "SELECT * FROM testTable"; $res = mysqli_query($mysqli, $sql); if($res) { //mysqli_fetch_array获取每一行构成的数组 while ($newArray = mysqli_fetch_array($res, MYSQLI_ASSOC)) { $id = $newArray['id']; $testField = $newArray['testField']; echo "第".$id."条的内容为".$testField."。"; } } else { //获取MYSQL错误信息 printf("查询失败: %s\n", mysqli_error($mysqli)); } //mysqli_free_result释放结果内存供其它脚本使用 mysqli_free_result($res); //显示关闭连接 mysqli_close($mysqli); } ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> </head> <body> </body> </html>
更多的MySQLi部分http://www.php.net/mysqli