php+mysql表格内记录行数据删除,怎样传递参数? 5
刚学php,工作需要,想做一个简单的内容管理,以下是做删除功能时出现的问题,请老师指点,谢谢!以下附上两个php文件,数据库用的网上下载的northwind数据库列表文件...
刚学php,工作需要,想做一个简单的内容管理,以下是做删除功能时出现的问题,请老师指点,谢谢!
以下附上两个php文件,数据库用的网上下载的northwind数据库
列表文件(list.php)
<!DOCTYPE html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>PHP+MySQL CRUD</title><style> #container{ margin: 5px auto; width:60%; } td{ height: 25px; border-bottom:solid 1px grey ; }</style></head><body><div id="container"><?php$conn = mysql_connect('localhost', 'root', '');if (!$conn) { die('Could not connect: ' . mysql_error());}mysql_select_db('northwind',$conn);mysql_query('SET NAMES UTF8');$result = mysql_query("SELECT * FROM customers") or die("Invalid query: " . mysql_error());echo "<table width='100%' cellspacing='0'>";echo "<thead><tr><th>姓名</th><th>城市</th><th>电话</th><th>操作</th></tr></thead>";while($row=mysql_fetch_array($result)){ echo "<tbody>"; echo "<tr>"; echo "<td>".$row['ContactName']."</td>"; echo "<td>".$row['City']."</td>"; echo "<td>".$row['Phone']."</td>"; echo "<td align='center'><a href='delet.php?id='".$row['CustomerID']."'> 删除</a></td>"; echo "</tr>"; echo "</tbody>"; };echo "<table/>";?> </div></body></html>
动作文件(delet.php)
<?php$conn = mysql_connect('localhost', 'root', '');if (!$conn) { die('Could not connect: ' . mysql_error());}mysql_select_db('northwind',$conn);mysql_query('SET NAMES UTF8');if(mysql_query("DELETE FROM customers WHERE CustomerID='".$_GET['id']."'")){ echo "<script>alert('ok');history.back();</script>"; }else{ echo "<script>alert('fail');history.back();</script>";}?>
列表界面
点删除超链接后,弹出窗口显示OK,但地址栏内好像并没有实现传参,再到主界面看,列表内相应记录也没有删除掉 展开
以下附上两个php文件,数据库用的网上下载的northwind数据库
列表文件(list.php)
<!DOCTYPE html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>PHP+MySQL CRUD</title><style> #container{ margin: 5px auto; width:60%; } td{ height: 25px; border-bottom:solid 1px grey ; }</style></head><body><div id="container"><?php$conn = mysql_connect('localhost', 'root', '');if (!$conn) { die('Could not connect: ' . mysql_error());}mysql_select_db('northwind',$conn);mysql_query('SET NAMES UTF8');$result = mysql_query("SELECT * FROM customers") or die("Invalid query: " . mysql_error());echo "<table width='100%' cellspacing='0'>";echo "<thead><tr><th>姓名</th><th>城市</th><th>电话</th><th>操作</th></tr></thead>";while($row=mysql_fetch_array($result)){ echo "<tbody>"; echo "<tr>"; echo "<td>".$row['ContactName']."</td>"; echo "<td>".$row['City']."</td>"; echo "<td>".$row['Phone']."</td>"; echo "<td align='center'><a href='delet.php?id='".$row['CustomerID']."'> 删除</a></td>"; echo "</tr>"; echo "</tbody>"; };echo "<table/>";?> </div></body></html>
动作文件(delet.php)
<?php$conn = mysql_connect('localhost', 'root', '');if (!$conn) { die('Could not connect: ' . mysql_error());}mysql_select_db('northwind',$conn);mysql_query('SET NAMES UTF8');if(mysql_query("DELETE FROM customers WHERE CustomerID='".$_GET['id']."'")){ echo "<script>alert('ok');history.back();</script>"; }else{ echo "<script>alert('fail');history.back();</script>";}?>
列表界面
点删除超链接后,弹出窗口显示OK,但地址栏内好像并没有实现传参,再到主界面看,列表内相应记录也没有删除掉 展开
若以下回答无法解决问题,邀请你更新回答
1个回答
展开全部
具体分析如下:
首先来说说为什么要有预处理(预编译)技术?举个例子:假设要向数据库添加100个用户,按常规思路,就是向数据库发送100个执行请求,此时,按照 mysql 数据库的工作原理,它需要对每一条执行语句进行编译(这里就有100次)。所以,这里的效率是非常低的。
预处理(预编译)技术的作用,就是减少编译的次数和时间,以提高效果。通过一个案例来说明,预处理(预编译)技术是如何做到的(好吧,先说清楚,当 php 程序第一次发送 sql 语句时,mysql 数据库就编译好,到了后面99次,php只要发送数据过去即可,不需要再进行编译)。
<?php
//1、创建数据库连接对象
$mysqli = new MySQLi("localhost","root","123456","liuyan");
if($mysqli->connect_error){
die($mysqli->connect_error);
}
$mysqli->query("set names 'GBK'");
//2、创建预编译对象
$sql = "insert into account(id,balance) values(?,?)";
//这里用 ? 来代替要插入的数据值
$stmt = $mysqli->prepare($sql);
//返回一个statement对象,对象中的方法见手册 MySQLi_STMT
//3、绑定参数(需要插入的数据),并执行
$id=null;//这里我数据库设置成了 primary key auto_increment
$balance=100.5;
$stmt->bind_param("id",$id,$balance);
//绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
//这里$id为int,用i表示,$balance为float型,用d表示,具体见手册
$res = $stmt->execute();//执行语句,返回值为布尔类型
//4、判断是否执行成功
if(!$res){
echo "数据插入失败,balance值为:".$balance;
}else{
echo "成功";
}
/*
*****插入第二条数据
*/
//3、绑定参数(需要插入的数据),并执行
$id=null;//这里我数据库设置成了 primary key auto_increment
$balance=400.3;
$stmt->bind_param("id",$id,$balance);
//绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
//这里$id为int,用i表示,$balance为float型,用d表示。
$res = $stmt->execute();//执行语句,返回值为布尔类型
//4、判断是否执行成功
if(!$res){
echo "数据插入失败,balance值为:".$balance;
}else{
echo "成功";
}
?>
首先来说说为什么要有预处理(预编译)技术?举个例子:假设要向数据库添加100个用户,按常规思路,就是向数据库发送100个执行请求,此时,按照 mysql 数据库的工作原理,它需要对每一条执行语句进行编译(这里就有100次)。所以,这里的效率是非常低的。
预处理(预编译)技术的作用,就是减少编译的次数和时间,以提高效果。通过一个案例来说明,预处理(预编译)技术是如何做到的(好吧,先说清楚,当 php 程序第一次发送 sql 语句时,mysql 数据库就编译好,到了后面99次,php只要发送数据过去即可,不需要再进行编译)。
<?php
//1、创建数据库连接对象
$mysqli = new MySQLi("localhost","root","123456","liuyan");
if($mysqli->connect_error){
die($mysqli->connect_error);
}
$mysqli->query("set names 'GBK'");
//2、创建预编译对象
$sql = "insert into account(id,balance) values(?,?)";
//这里用 ? 来代替要插入的数据值
$stmt = $mysqli->prepare($sql);
//返回一个statement对象,对象中的方法见手册 MySQLi_STMT
//3、绑定参数(需要插入的数据),并执行
$id=null;//这里我数据库设置成了 primary key auto_increment
$balance=100.5;
$stmt->bind_param("id",$id,$balance);
//绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
//这里$id为int,用i表示,$balance为float型,用d表示,具体见手册
$res = $stmt->execute();//执行语句,返回值为布尔类型
//4、判断是否执行成功
if(!$res){
echo "数据插入失败,balance值为:".$balance;
}else{
echo "成功";
}
/*
*****插入第二条数据
*/
//3、绑定参数(需要插入的数据),并执行
$id=null;//这里我数据库设置成了 primary key auto_increment
$balance=400.3;
$stmt->bind_param("id",$id,$balance);
//绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
//这里$id为int,用i表示,$balance为float型,用d表示。
$res = $stmt->execute();//执行语句,返回值为布尔类型
//4、判断是否执行成功
if(!$res){
echo "数据插入失败,balance值为:".$balance;
}else{
echo "成功";
}
?>
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询