新聞中心
sqlserver函數(shù)中引用遞歸
set?@p_b?=?(select?fid?from?w_Storage_Depository?where?fid?in(select?fid?from?dbo.jt_base_company?where?bj=1))
覃塘網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站設(shè)計(jì)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)建站2013年開創(chuàng)至今到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
改成
select??@p_b?=fid?from?w_Storage_Depository?where?fid?in(select?fid?from?dbo.jt_base_company?where?bj=1)
請(qǐng)問sqlserver2000怎么實(shí)現(xiàn)遞歸查詢,詳細(xì)是 我的表有兩個(gè)字段id,parentId 我只知道中國(guó)--四川--成都
不用遞歸
建兩個(gè)表1省;表2城市,建立視圖 關(guān)系1對(duì)多,表1—〉表2,
select 視圖 就可以查出了
數(shù)據(jù)庫(kù)語(yǔ)句的遞歸查詢求助
應(yīng)該是這樣:
with qry as (select user_id,parent_id from tab where user_id = 32
union all
select tab.user_id,tab.parent_id from tab,qry
where tab.parent_id = qry.id)
select * from qry ;
我用mysql5.0.22,不支持上述語(yǔ)法,oracle就可以(sqlserver應(yīng)該也可以):
create table tab1(user_id int, parent_id int);
insert into tab1 values(1,null);
insert into tab1 values(32,1);
insert into tab1 values(101,32);
insert into tab1 values(102,32);
insert into tab1 values(201,101);
insert into tab1 values(202,101);
insert into tab1 values(203,102);
insert into tab1 values(204,102);
select * from tab1;
with qry(user_id,parent_id) as (select user_id,parent_id from tab1 where user_id = 32
union all
select tab1.user_id,tab1.parent_id from tab1,qry
where tab1.parent_id = qry.user_id
)
select * from qry;
所以,mysql沒有辦法了,只有寫函數(shù),用循環(huán)來(lái)實(shí)現(xiàn)了。
sqlserver查詢樹形結(jié)構(gòu)的所有子節(jié)點(diǎn)
用標(biāo)準(zhǔn)sql的with實(shí)現(xiàn)遞歸查詢(sql2005以上肯定支持,sql2000不清楚是否支持):
with subqry(id,name,pid) as (
select id,name,pid from test1 where id = 5
union all
select test1.id,test1.name,test1.pid from test1,subqry
where test1.pid = subqry.id
)
select * from subqry;
SQL Server 兩個(gè)表遞歸
with district as ( select * from SECFUNMODULE where MENUID='030' union all select a.* from SECFUNMODULE a, district b where a.PMENUID = b.MENUID ), district1 as ( select a.* from district a where a.MENUID in (select PMENUID from district) ) select * from district1 order by MENUID with當(dāng)然可以實(shí)現(xiàn). 請(qǐng)參照sqlserver2005 的遞歸查詢
sql語(yǔ)句中怎么實(shí)現(xiàn)遞歸查詢
在SQL
SERVER
2000
中你可以先一些自定義函數(shù),或一些存儲(chǔ)過程,實(shí)現(xiàn)遞歸:
select
level,TypeName
from
ProductType
t
START
WITH
t.ParentID=0
CONNECT
BY
PRIOR
t.ProductTypeID=
t.ParentID;
文章題目:sqlserver遞歸查詢,sqlserver遞歸查詢層級(jí)
文章起源:http://www.ef60e0e.cn/article/dsccehp.html