首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何根据"depth“缩进查询输出?

如何根据"depth“缩进查询输出?
EN

Stack Overflow用户
提问于 2013-03-16 05:49:11
回答 2查看 1.2K关注 0票数 0

想象一下这样一个表:

代码语言:javascript
复制
create table test (depth integer, name text);

添加一些行:

代码语言:javascript
复制
insert into test (depth, name)
values (0, "no indent"), (1, "single indent"), (2, "double indent");

现在,根据depth参数创建输出,如下所示:

代码语言:javascript
复制
no indent
    single indent
        double indent

在这种情况下,缩进是4个空格(但可以更改为任何有趣的缩进,如制表符)。

我的直觉想要这样做:

代码语言:javascript
复制
select '    ' * depth || name from test order by depth;

然而,这在Postgres中失败了。在Python中,像这样的字符串乘法可以正常工作。但是,我对Postgres中的等效操作并不熟悉。其他的数据库实现也会很有趣。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-16 05:59:08

使用lpad()

代码语言:javascript
复制
select lpad(name, (4 * depth) + length(name), ' ')
from test 
order by depth;

repeat() +连接:

代码语言:javascript
复制
select repeat('_', 4 * depth) || name
from test 
order by depth;

http://www.postgresql.org/docs/current/static/functions-string.html

票数 2
EN

Stack Overflow用户

发布于 2013-03-16 06:08:27

我没有访问Postgresql的权限,但在SQL上,前导空格会自动取消。

我改变了空格来加下划线,它起作用了。

我的代码(基于REPEAT):

代码语言:javascript
复制
select REPEAT(REPEAT('_', 4), depth) || name as "Column" from test order by depth;

链接到包含您的数据的SQL Fiddle:http://sqlfiddle.com/#!1/96f11/4

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15442649

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档