如題,本次是要實現點擊超鏈接實現執行js代碼,並確認是否刪除數據庫數據,采用php。
首先鏈接數據庫,查詢數據庫數據:
復制代碼 代碼如下:
<?php
$dbms='mysql'; //數據庫類型 ,對於開發者來說,使用不同的數據庫,只要改這個,不用記住那麼多的函數
$host='localhost'; //數據庫主機名
$dbName='db_database19'; //使用的數據庫
$user='root'; //數據庫連接用戶名
$pass='root'; //對應的密碼
$dsn="$dbms:host=$host;dbname=$dbName";
try {
$pdo = new PDO($dsn, $user, $pass); //初始化一個PDO對象,就是創建了數據庫連接對象$pdo
$query="select * from tb_pdo_mysql"; //定義SQL語句
$result=$pdo->prepare($query); //准備查詢語句
$result->execute(); //執行查詢語句,並返回結果集
while($res=$result->fetch(PDO::FETCH_ASSOC)){ //while循環輸出查詢結果集,並且設置結果集的為關聯索引
?>
<tr>
<td height="22" align="center" valign="middle"><?php echo $res['id'];?></td>
<td align="center" valign="middle"><?php echo $res['pdo_type'];?></td>
<td align="center" valign="middle"><?php echo $res['database_name'];?></td>
<td align="center" valign="middle"><?php echo $res['dates'];?></td>
<td align="center" valign="middle"><a href="javascript:del(<?php echo $res['id']?>)">刪除</a></td>
</tr>
<?php
}
} catch (PDOException $e) {
die ("Error!: " . $e->getMessage() . "<br/>");
}
?>
在超鏈接刪除處調用一javascript方法,傳遞記錄id,js方法為:
復制代碼 代碼如下:
<script>
function del(_id) {
if (confirm("確認刪除"))
{
window.location.href="index.php?conn_id="+_id; //本頁面刷新
}
}
</script>
刪除數據庫記錄代碼:
復制代碼 代碼如下:
<?php
if(@$_GET['conn_id']!=""){
$dbms='mysql'; //數據庫類型 ,對於開發者來說,使用不同的數據庫,只要改這個,不用記住那麼多的函數
$host='localhost'; //數據庫主機名
$dbName='db_database19'; //使用的數據庫
$user='root'; //數據庫連接用戶名
$pass='root'; //對應的密碼
$dsn="$dbms:host=$host;dbname=$dbName";
try {
$pdo = new PDO($dsn, $user, $pass); //初始化一個PDO對象,就是創建了數據庫連接對象$pdo
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$query="delete from tb_pdo_mysql where Id=:id";
$result=$pdo->prepare($query); //預准備語句
$result->bindParam(':id',$_GET['conn_id']); //綁定更新的數據
$result->execute();
} catch (PDOException $e) {
echo 'PDO Exception Caught.';
echo 'Error with the database:<br/>';
echo 'SQL Query: '.$query;
echo '<pre>';
echo "Error: " . $e->getMessage(). "<br/>";
echo "Code: " . $e->getCode(). "<br/>";
echo "File: " . $e->getFile(). "<br/>";
echo "Line: " . $e->getLine(). "<br/>";
echo "Trace: " . $e->getTraceAsString(). "<br/>";
echo '</pre>';
}
}
?>
這段代碼放在html頁面body部分最開頭處,最壞也要放在查詢記錄代碼之前。
呵呵,這個簡單啊,
<a href="del.php?id=1 onclick="return confirm('確認需要刪除些信息嗎?');>刪除</a>
點確定就直接跳到刪除頁去了。
點取消就原樣不動。
php獲取url參數
$id = $_GET[id];
要是還有什麼不明白的,可以真通過百度Hi給我留言。
<a href="delete.php?id=xxx" >刪除</a>
foreach遍歷數據的時候 寫上id值,然後delete.php頁面執行刪除操作。
要麼你把連數據庫的頁面包含到 delete.php(不推薦)
要麼 都寫在一個頁面,然後switch case 判斷操作 接受id 然後執行
<a href="delete.php?act=del&id=xxx" >刪除</a> 這樣比較推薦
delete.php頁面裡
連好數據庫 switch($act=$_GET['act']){ case 'del': .........;break;case....}