RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
php数据库级联删除 phpstudy删除数据库

数据库级联删除怎么实现?

可以用下边的方法,仅供参考:

阿巴嘎网站制作公司哪家好,找成都创新互联公司!从网页设计、网站建设、微信开发、APP开发、响应式网站等网站项目制作,到程序开发,运营维护。成都创新互联公司从2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联公司

-- 创建测试主表. ID 是主键.

CREATE TABLE test_main (

id INT NOT NULL,

value VARCHAR(10),

PRIMARY KEY(id)

);

-- 创建测试子表.

CREATE TABLE test_sub (

id INT NOT NULL,

main_id INT ,

value VARCHAR(10),

PRIMARY KEY(id)

);

-- 插入测试主表数据.

INSERT INTO test_main(id, value) VALUES (1, 'ONE');

INSERT INTO test_main(id, value) VALUES (2, 'TWO');

-- 插入测试子表数据.

INSERT INTO test_sub(id, main_id, value) VALUES (1, 1, 'ONEONE');

INSERT INTO test_sub(id, main_id, value) VALUES (2, 2, 'TWOTWO');

然后,创建外键,使用 ON DELETE CASCADE 选项,删除主表的时候,同时删除子表

ALTER TABLE test_sub ADD CONSTRAINT main_id_cons FOREIGN KEY (main_id) REFERENCES test_main ON DELETE CASCADE;

执行删除:

DELETE FROM TEST_MAIN WHERE ID = 1;

最后:

SELECT * FROM TEST_MAIN;

结果子表中就只有ID=2的记录,也就说明级联删除成功。

PHP怎样用迭代法删除级联目录?

可以删除的,删除的时候检测是文件还是目录,如果是目录,进入查看是否有文件,继续删除,

在php中做级联删除的sql语句怎么写(一般的就行)但要是用触发器的话在php代码中又怎么写呢?

首先说明一下,做级联最好用ajax实现才好,例如下面这个例子。用ajax 实现三级级联菜单。

index.php:

html

head

meta http-equiv="Content-Type" content="text/html; charset=gb2312"

titleAjax联动菜单/title

script language="javascript" type="text/javascript" src="aa.js"/script

/head

body

form

label

select name="sel" id="sel" onChange="showMenu(this.value);"

option一级分类/option

?php

$conn = mysql_connect('localhost', 'root', '') or die('Could not connect: ' . mysql_error());

mysql_select_db('fitment', $conn) or die ('Can\'t use database : ' . mysql_error());

mysql_query("set names 'gb2312'");

$str = "SELECT * FROM `fitment_sort` where supid = '0' ORDER BY `id` ASC";

$result = mysql_query($str) or die("Invalid query: " . mysql_error());

if($result)

{

while ($arr = mysql_fetch_array($result)){

echo EOD

option value={$arr["id"]}{$arr["name"]}/option

EOD;

}

}

mysql_close($conn);

?

/select

/label

label

select name="sel2" id="sel2" onChange="showMenu2(this.value)"

option二级分类/option

/select

/label

label

select name="sel3" id="sel3"

option三级分类/option

/select

/label

/form

input type=button value="send value" onClick="alert(document.getElementByIdx('sel').options[document.getElementByIdx('sel').selectedIndex].text + '-' + document.getElementByIdx('sel2').options[document.getElementByIdx('sel2').selectedIndex].text + '-' + document.getElementByIdx('sel3').options[document.getElementByIdx('sel3').selectedIndex].text)"

/body

/html

aa.js

!--

var xmlHttp

var xmlHttp2

//函数showMenu(str) - 功能函数1

function showMenu(str)

{

xmlHttp=GetXmlHttpObject() //调用GetXmlHttpObject()函数,创建XMLHttpRequest对象

if (xmlHttp==null) //如果创建失败,则

{

alert ("Browser does not support HTTP Request")

return

}

var url="get2.php" //定义url , 其主要读取数据库

url=url+"?q="+str

url=url+"sid="+Math.random() //Math对象的random方法,取随机数

xmlHttp.onreadystatechange=stateChanged //设置当XMLHttpRequest对象xmlHttp状态改变时调用的函数,注意函数名后不要添加小括号

xmlHttp.open("GET",url,true) //使用XMLHttpRequest对象的open()方法 , 创建HTTP请求

xmlHttp.send(null) //使用XMLHttpRequest对象的open()方法 , 发送HTTP请求

}

//函数showMenu(str) - 功能函数1

function showMenu2(str)

{

xmlHttp2=GetXmlHttpObject() //调用GetXmlHttpObject()函数,创建XMLHttpRequest对象

if (xmlHttp2==null) //如果创建失败,则

{

alert ("Browser does not support HTTP Request")

return

}

var url="get2.php" //定义url , 其主要读取数据库

url=url+"?q2="+str

url=url+"sid="+Math.random() //Math对象的random方法,取随机数

xmlHttp2.onreadystatechange=stateChanged2 //设置当XMLHttpRequest对象xmlHttp状态改变时调用的函数,注意函数名后不要添加小括号

xmlHttp2.open("GET",url,true) //使用XMLHttpRequest对象的open()方法 , 创建HTTP请求

xmlHttp2.send(null) //使用XMLHttpRequest对象的open()方法 , 发送HTTP请求

}

//函数BuildSel() , 根据返回的的字串 , 重新构建新的下拉菜单控件Select - 功能函数2

function BuildSel(str,sel)

{

//先清空原来的数据.

sel.options.length=0;

//定义一个数组对象

var arrstr = new Array();

//以","号拆分传入的字串,并存入数组

arrstr = str.split(",");

if(str.length0)

{

//循环

for(var i=0;iarrstr.length;i++)

{

var subarrstr=new Array();

//以"|"拆分

subarrstr=arrstr[i].split("|");

sel.options.add(new Option(subarrstr[1],subarrstr[0]));

}

sel.options[0].selected=true;

}

}

//函数stateChanged() - 响应HTTP请求状态变化

function stateChanged()

{

//判断XMLHttpRequest对象的readyState属性值是否为4,如果为4表示异步调用完成(注意:异步调用完成 不代表异步调用成功)

if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")

{

//如果异步调用成功 -- XMLHttpRequest对象的status属性值为200 , html文件在本地运行,则xmlHttp.status的返回值为0,故应该加上xmlHttp.status==0

if(xmlHttp.status==200 || xmlHttp.status==0)

{

//调用文档对象模型DOM的getElementById()方法查找html文件中的标签txtHint ,

//innerHTML为IE浏览器中的属性,可以用来更改标签间文本的内容 ,

//xmlHttp.responseText , 通过XMLHttpRequest的responseText属性来获取数据 responseText,结果为字符串;responseXML,结果为XML形式

// document.getElementByIdx("txtHint").innerHTML=xmlHttp.responseText

BuildSel(xmlHttp.responseText,document.getElementsByTagName_r("*").sel2)

showMenu2(document.getElementsByTagName_r("*").sel2.value);

}

}

}

//函数stateChanged() - 响应HTTP请求状态变化

function stateChanged2()

{

//判断XMLHttpRequest对象的readyState属性值是否为4,如果为4表示异步调用完成(注意:异步调用完成 不代表异步调用成功)

if (xmlHttp2.readyState==4 || xmlHttp2.readyState=="complete")

{

//如果异步调用成功 -- XMLHttpRequest对象的status属性值为200 , html文件在本地运行,则xmlHttp.status的返回值为0,故应该加上xmlHttp.status==0

if(xmlHttp2.status==200 || xmlHttp2.status==0)

{

//调用文档对象模型DOM的getElementById()方法查找html文件中的标签txtHint ,

//innerHTML为IE浏览器中的属性,可以用来更改标签间文本的内容 ,

//xmlHttp.responseText , 通过XMLHttpRequest的responseText属性来获取数据 responseText,结果为字符串;responseXML,结果为XML形式

// document.getElementByIdx("txtHint").innerHTML=xmlHttp.responseText

BuildSel(xmlHttp2.responseText,document.getElementsByTagName_r("*").sel3)

}

}

}

//函数GetXmlHttpObject() - 创建XMLHttpRequest对象,即创建一个异步调用对象

function GetXmlHttpObject()

{

var xmlHttp=null;

try

{

// Firefox, Opera 8.0+, Safari

xmlHttp=new XMLHttpRequest();

}

catch (e)

{

//Internet Explorer

try

{

xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");

}

catch (e)

{

xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");

}

}

return xmlHttp;

}

--

get2.php

?php

//指定编码

header('Content-Type:text/html;charset=GB2312');

//连接、选择数据库,设置字符集

$conn = mysql_connect('localhost', 'root', '') or die('Could not connect: ' . mysql_error());

mysql_select_db('fitment', $conn) or die ('Can\'t use database : ' . mysql_error());

mysql_query("set names 'gb2312'");

//如果传递过来q

if($_GET["q"]){

$strs = "SELECT * FROM fitment_sort WHERE supid=' ".$_GET["q"]."' ";

//echo $str;

$results = mysql_query($strs) or die("Invalid query: " . mysql_error());

if($results)

{

while ($arrs = mysql_fetch_array($results)){

$strings .= $arrs["id"]."|".$arrs["name"].",";

}

echo substr($strings,0,strlen($strings)-1);

}

}

//如果传递过来q2

if($_GET["q2"]){

$str = "SELECT * FROM fitment_sort WHERE supid= '".$_GET["q2"]."'";

//echo $str;

$result = mysql_query($str) or die("Invalid query: " . mysql_error());

if($result)

{

while ($arr = mysql_fetch_array($result)){

$string .= $arr["id"]."|".$arr["name"].",";

}

//去掉字串最后一个字符","

echo substr($string,0,strlen($string)-1);

}

}

mysql_close($conn);

?

删除的sql语句

delete from class where classid=$_GET[classid]

其中是$_GET[classid] 是选项中 option 的值就可以了。


分享名称:php数据库级联删除 phpstudy删除数据库
转载注明:http://lswzjz.com/article/ddsdihc.html