当前位置:首页 » 操作系统 » 数据库connectby

数据库connectby

发布时间: 2025-05-24 03:46:15

1. 如何优化start with connect by prior

用 with .. as

实现递归。

供参考:

Oracle自己提供的是 connect by ... start with,而别的数据库只有使用With来实现

create tabletest1(id number, name varchar2(20), pid number);

insert intotest1 values(1,'电器',null);
insert intotest1 values(2,'家电',1);
insert intotest1 values(3,'冰箱',2);
insert intotest1 values(4,'洗衣机',2);
insert intotest1 values(5,'电脑',1);
insert intotest1 values(6,'笔记本',5);
insert intotest1 values(7,'平板',5);
insert intotest1 values(8,'组装机',7);
insert intotest1 values(9,'品牌机',7);

withsubqry(id,name,pid) as(
select id,name,pid fromtest1 where id= 5
union all
selecttest1.id,test1.name,test1.pid fromtest1,subqry
wheretest1.pid = subqry.id
)
select* fromsubqry;

drop tabletest1;

2. 求助,oracle的connect by功能转换到mysql如何

在Oracle中sql代码如下编写

select o.orgid from t_organization o
connect by prior o.orgid = o.orgparentid
start with o.orgid = #{params.swjgDm}

那么在MySQL数据库中需要改为如下方式

select o.orgid from t_organization o where
(o.ORGPARENTIDS LIKE concat('%/',#{params.swjgDm},'/%')
or o.ORGID =#{params.swjgDm}) and o.AVAILABLE ='1'

3. oracle SQL查询时提示 用户数据中的connect by 循环 报错是什么原因

一般是数据错误导致了死循环。
如数据为这样:
ID 父ID 值
1 2 10
2 1 20

如图,ID为1的父ID为2,而同时ID为2的父ID是1,这样的话,就会互相认对方的ID为父ID,就会造成一个死循环,这种错误,一般不用修改语句,需要正确检查数据的正确性。

热点内容
域控制服务器dns和ip 发布:2025-08-20 16:05:21 浏览:538
怎样让隐藏文件夹显示 发布:2025-08-20 16:03:37 浏览:35
如何辨别密码箱密码锁坏了 发布:2025-08-20 16:02:47 浏览:969
河池都安服务器ip地址是什么 发布:2025-08-20 16:00:13 浏览:873
做自媒体剪辑需要什么配置的电脑 发布:2025-08-20 15:37:38 浏览:388
密码法的立法目地是什么 发布:2025-08-20 15:27:13 浏览:456
不小心删除微信怎么恢复聊天记录安卓 发布:2025-08-20 15:27:05 浏览:449
车载安卓系统指的是什么 发布:2025-08-20 15:23:47 浏览:713
安徽鲲鹏服务器云空间 发布:2025-08-20 15:19:37 浏览:790
怎样删除手机大存储 发布:2025-08-20 15:10:36 浏览:270