On 05-Feb-2014 10:57 -0800, Jack Tucky wrote:
I have a file with a catalog# in it. I want to view/print a list of
the lengths of the data within the field. I want one record per
length.

The catalog# is defined as 20 characters, I was able to use
CHAR_LENGTH(STRIP(CAT#)) to see the lengths.

How can I make SQL give me one result like this:

Length count
20 1500
19 5000
18 10000
17 20000
Etc.

I tried this but I get an error, Column list required

create table wrk/counter as
( select
cat#
, CHAR_LENGTH(STRIP(CAT#))
from FILE
where cat#<> ' '
) with data

For that error SQL0153 [sqlcode -153], the resolution is to give the expression a name. The CREATE TABLE needs to have a name for each column that will be created, and as the message suggest, the SELECT list includes an expression without an AS-name clause. Variants of the following would suffice:

create table wrk/counter as
( select
cat#
, CHAR_LENGTH(STRIP(CAT#)) AS CatLen
/* Use AS clause to name col; either System or Alternative name */
from ...

create table wrk/counter
( catnbr, CatCharLength )
/* use column list to give Alias\Alternative or System names */
as
( select ...

create table wrk/counter
( CatNbr for cat#, CatCharLength for CatLen )
/* use col list: give both Alias\Alternative and System names */
as
( select ...

See the syntax diagram for the as-result-table in CREATE TABLE for naming columns using the list vs the naming in the SELECT statement:
<http://pic.dhe.ibm.com/infocenter/iseries/v7r1m0/topic/db2/rbafzhctabl.htm>

As for the desired output... Not sure of any apparent need to create a[n intermediate] table with the data. Directly obtaining the data for the reporting while allowing the query possibly to implement with a temporary table is possible; i.e. no need for a CREATE TABLE.

Regardless, the following should suffice [along with giving explicit data type and length; generally desirable with CREATE TABLE], although coded below, using the scalar function RTRIM [or TRIM(TRAILING,...)] instead of the scalar function STRIP [or TRIM(BOTH,...) as shown, per the former more typically being the desired effect:

select
dec( char_length( rtrim( cat# ) ), 2 ) as "Length"
, dec( count(*), 9 ) as "count"
from FILE
where cat#<>''
group by
dec( char_length( rtrim( cat# ) ), 2 )
order by 1 desc
/* or: order by
dec( char_length( rtrim( cat# ) ), 2 ) desc */

Composed using a Common Table Expression (CTE), the requirement to specify the expression repeatedly [as shown in the above query] can be eliminated:

with
CntLen as
( select
dec( char_length( rtrim( cat# ) ), 2 ) as "Length"
from FILE
where cat#<>''
)
select
"Length"
, dec( count(*), 9 ) as "count"
from CntLen
group by "Length"
order by "Length" desc

Although explicitly stated just "one record per length", might a row need to appear for each possible "Length" value from one to twenty; i.e. produce a row with a count equal to zero, for any character_length value not represented across the rows of cat# data in FILE? If so, then perhaps the following is functional as coded; I can not test the use of the row values clause inside the table():

select ifnull("Length", nbr), ifnull("count", 0)
from
( select
dec( char_length( rtrim( cat# ) ), 2 ) as "Length"
, dec( count(*), 9 ) as "count"
from FILE
where cat#<>''
group by dec( char_length( rtrim( cat# ) ), 2 )
) as cntlen ("Length", "count") /* override AS-name above */
right outer join
table( values(dec(20, 2)), (19), (18), (17), (16)
, (15), (14), (13), (12), (11)
, (10), (09), (08), (07), (06)
, (05), (04), (03), (02), (01)
) as cntnbr ( nbr )
on "Length" = nbr
order by nbr desc


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.