× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Thanks, everyone, for your suggestions, and your time preparing them.

Have a wonderful Thanksgiving!

Best Regards,

Thomas Garvey


On 11/24/2020 11:46 AM, Tim Fathers wrote:
You could try a recursive CTE, it's not pretty but it does the trick. In the view below, the constant "2" is the length of each shipment value you want to extract, change it everywhere if it's different in your real-life case.

Tim.

-- Create some test data.
declare global temporary table TEST_DATA as (
select *

from(values
(1, 'A B C D E'),
(2, 'A B'),
(3, 'A B C'),
(4, ''),
(5, 'Z Y X')
) x(ORDER_NUMBER, COMPOSITE_SHIP_NUMBERS)
) with data with replace
;;


-- Create the view.
create or replace view QTEMP.NORMALISED as (
with RECURSIVE_CTE (
ORDER_NUMBER,
START_POS,
COMPOSITE_SHIP_NUMBERS,
SHIPMENT_NUMBER
) as (

select ORDER_NUMBER, -- From the original table
1 as START_POS,
COMPOSITE_SHIP_NUMBERS, -- From the original table
substring(COMPOSITE_SHIP_NUMBERS, 1, 2) as SHIPMENT_NUMBER

from TEST_DATA -- Original non-normalised table

union all

select ORDER_NUMBER,
START_POS + 2 as START_POS,
COMPOSITE_SHIP_NUMBERS,
substring(COMPOSITE_SHIP_NUMBERS, START_POS + 2, 2) as SHIPMENT_NUMBER

from RECURSIVE_CTE

where START_POS + 2 <= length(COMPOSITE_SHIP_NUMBERS)
)

select ORDER_NUMBER, SHIPMENT_NUMBER from RECURSIVE_CTE where SHIPMENT_NUMBER <> ''
)
;;

-- Test the view.
select * from QTEMP.NORMALISED order by ORDER_NUMBER, SHIPMENT_NUMBER







________________________________
From: MIDRANGE-L <midrange-l-bounces@xxxxxxxxxxxxxxxxxx> on behalf of Thomas Garvey <tgarvey@xxxxxxxxxx>
Sent: 24 November 2020 16:11
To: midrange-l@xxxxxxxxxxxxxxxxxx <midrange-l@xxxxxxxxxxxxxxxxxx>
Subject: Re: Using a temp normalized table in SQL view...

Thanks for these suggestions.

Unfortunately, I don't think they're available to me. I have to support
older OS versions. And the split function looks like it needs a
delimiter between elements to normalize the data. My elements are not
delimited by any characters. Just a compressed string, subdivided by
substring length.

Best Regards,

Thomas Garvey

On 11/23/2020 10:51 PM, Birgitta Hauser wrote:

Example (using Split):
Select OrderNo, Element
from Mytable cross join Table(SysTools.Split(Shipments, ' ')) x;

Mit freundlichen Grüßen / Best regards

Birgitta Hauser


"Shoot for the moon, even if you miss, you'll land among the stars." (Les Brown)
"If you think education is expensive, try ignorance." (Derek Bok)
"What is worse than training your staff and losing them? Not training them and keeping them!"
„Train people well enough so they can leave, treat them well enough so they don't want to.“ (Richard Branson)


-----Original Message-----
From: MIDRANGE-L <midrange-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of Thomas Garvey
Sent: Montag, 23. November 2020 21:52
To: Midrange Systems Technical Discussion <midrange-l@xxxxxxxxxxxxxxxxxx>
Subject: Using a temp normalized table in SQL view...

I have a stored SQL procedure that normalizes data elements from one file into a temporary table.
For example, non-normalized data looks like this...

Order Number Shipment Numbers
1 A B C D E
2 A B
3 A B C
4
5 Z Y X

Would result in normalized data, in the new table in QTEMP.

Order Number Shipment Number
1 A
1 B
1 C
1 D
1 E
2 A
2 B
3 A
3 B
3 C
5 Z
5 Y
5 X

Now comes the problem. I want to include this normalized data from QTEMP into an SQL view.
I get SQL7008 FileName in QTEMP not valid for operation My read of the supporting message description is that you can't use a table in QTEMP as part of a view.

Now I'm wondering if I can use the WITH SQL statement (using a CTE) in the view definition. I've never used CTE but my understanding of it is that the WITH AS is basically informing SQL of a table that will be used in the following compound SQL statement is defined as the WITH AS segment defines it. If that is right, then how/where does my stored procedure come in that actually builds that QTEMP file?

You're probably thinking, why not just create the normalized table as a permanent table in a standard library? The problem there is that the file of non-normalized data can be updated at any time, necessitating a rebuild of the normalized data table. If that normalized table is in use by another user, it would be unable to be rebuilt. At best, it would be inaccurate.

Any ideas/thoughts?

--
Warm Regards,

Thomas Garvey

--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list To post a message email: MIDRANGE-L@xxxxxxxxxxxxxxxxxx To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives at https://archive.midrange.com/midrange-l.

Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related questions.

Help support midrange.com by shopping at amazon.com with our affiliate link: https://amazon.midrange.com

--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list
To post a message email: MIDRANGE-L@xxxxxxxxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: https://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxxxxxxxx
Before posting, please take a moment to review the archives
at https://archive.midrange.com/midrange-l.

Please contact support@xxxxxxxxxxxxxxxxxxxx for any subscription related questions.

Help support midrange.com by shopping at amazon.com with our affiliate link: https://amazon.midrange.com

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

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.