множественное количество (подстрока) с оконным psql 8.4.4 - PullRequest
0 голосов
/ 24 июня 2010

Я пытаюсь создать следующий вид, и я получаю ошибку ниже: Я могу сделать 1 оператор подсчета (если я удаляю AS "Mod0") Можно ли подсчитать несколько подстрок с подсчетом вывода в новый столбец?

create view portcnt as 
    select 
    address,
    datacenter,
    ifdesc,
    count(substring(ifdesc, 'Ethernet0/*')) as "Mod0",
    count(substring(ifdesc, 'Ethernet1/*')) as "Mod1",
    count(substring(ifdesc, 'Ethernet2/*')) as "Mod2",
    count(substring(ifdesc, 'Ethernet3/*')) as "Mod3",
    count(substring(ifdesc, 'Ethernet4/*')) as "Mod4",
    count(substring(ifdesc, 'Ethernet5/*')) as "Mod5",
    count(substring(ifdesc, 'Ethernet6/*')) as "Mod6"
    over (partition by address)
    from ifstatus where datacenter = 'DC' 
    and ifadminstatus = '1' and ifoperstatus = '1';
ERROR:  syntax error at or near "by"
LINE 13:  over (partition by address)

1 Ответ

1 голос
/ 24 июня 2010

нашел решение, которое сработало:

create view portcnt1 as
    select
    address,
    datacenter,
    ifdesc,
    count(substring(ifdesc, 'Ethernet0/*')) 
    over (partition by address) mod0,
    count(substring(ifdesc, 'Ethernet1/*'))
    over (partition by address) mod1,
    count(substring(ifdesc, 'Ethernet2/*'))
    over (partition by address) mod2,
    count(substring(ifdesc, 'Ethernet3/*'))
    over (partition by address) mod3,
    count(substring(ifdesc, 'Ethernet4/*'))
    over (partition by address) mod4,
    count(substring(ifdesc, 'Ethernet5/*'))
    over (partition by address) mod5,
    count(substring(ifdesc, 'Ethernet6/*'))
    over (partition by address) mod6,
    count(substring(ifdesc, 'Ethernet7/*'))
    over (partition by address) mod7,
    count(substring(ifdesc, 'Ethernet8/*'))
    over (partition by address) mod8,
    count(substring(ifdesc, 'Ethernet9/*'))
    over (partition by address) mod9
    from ifstatus
    where ifadminstatus = '1' and ifoperstatus = '1';
...