13.07.2015 Views

IBM Flex System x240 w

IBM Flex System x240 w

IBM Flex System x240 w

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

, W_CITY CHAR(20), W_STATE CHAR(2), W_ZIP CHAR(9), D_STREET_1 CHAR(20), D_STREET_2 CHAR(20), D_CITY CHAR(20), D_STATE CHAR(2), D_ZIP CHAR(9), C_LAST VARCHAR(16), C_FIRST VARCHAR(16), C_MIDDLE CHAR(2), C_STREET_1 VARCHAR(20), C_STREET_2 VARCHAR(20), C_CITY VARCHAR(20), C_STATE CHAR(2), C_ZIP CHAR(9), C_PHONE CHAR(16), C_SINCE TIMESTAMP, C_CREDIT CHAR(2), C_CREDIT_LIM DECIMAL(12,2), C_DISCOUNT REAL, C_BALANCE DECIMAL(12,2), C_DATA CHAR(200), H_DATE TIMESTAMP)SPECIFIC PAY_C_IDMODIFIES SQL DATA DETERMINISTIC NO EXTERNAL ACTION LANGUAGE SQLVAR: BEGIN ATOMICDECLARE W_NAME CHAR(10) ;DECLARE D_NAME CHAR(10) ;DECLARE W_STREET_1 CHAR(20) ;DECLARE W_STREET_2 CHAR(20) ;DECLARE W_CITY CHAR(20) ;DECLARE W_STATE CHAR(2) ;DECLARE W_ZIP CHAR(9) ;DECLARE D_STREET_1 CHAR(20) ;DECLARE D_STREET_2 CHAR(20) ;DECLARE D_CITY CHAR(20) ;DECLARE D_STATE CHAR(2) ;DECLARE D_ZIP CHAR(9) ;DECLARE C_LAST VARCHAR(16) ;DECLARE C_FIRST VARCHAR(16) ;DECLARE C_MIDDLE CHAR(2) ;DECLARE C_STREET_1 VARCHAR(20) ;DECLARE C_STREET_2 VARCHAR(20) ;DECLARE C_CITY VARCHAR(20) ;DECLARE C_STATE CHAR(2) ;DECLARE C_ZIP CHAR(9) ;DECLARE C_PHONE CHAR(16) ;DECLARE C_SINCE TIMESTAMP ;DECLARE C_CREDIT CHAR(2) ;DECLARE C_CREDIT_LIM DECIMAL(12,2) ;DECLARE C_DISCOUNT REAL ;DECLARE C_BALANCE DECIMAL(12,2) ;DECLARE C_DATA CHAR(200) ;DECLARE H_DATE TIMESTAMP;/* Generate the current date and time for the payment date */SET H_DATE = CURRENT TIMESTAMP;/* Update District and retieve its data */SET ( D_NAME, D_STREET_1, D_STREET_2, D_CITY, D_STATE, D_ZIP );= ( SELECT D_NAME, D_STREET_1, D_STREET_2, D_CITY, D_STATE, D_ZIP)FROM OLD TABLE ( UPDATE DISTRICT/* Update the customer matching C_ID */SET (SET D_YTD = D_YTD + PAY_C_ID.H_AMOUNTWHERE D_W_ID = PAY_C_ID.W_IDAND D_ID = PAY_C_ID.D_ID) AS UC_LAST, C_FIRST, C_MIDDLE, C_STREET_1, C_STREET_2, C_CITY, C_STATE, C_ZIP, C_PHONE, C_SINCE, C_CREDIT, C_CREDIT_LIM, C_DISCOUNT, C_BALANCE, C_DATA )= ( SELECT C_LAST, C_FIRST, C_MIDDLE, C_STREET_1, C_STREET_2, C_CITY, C_STATE, C_ZIP, C_PHONE, C_SINCE, C_CREDIT, C_CREDIT_LIM, C_DISCOUNT, C_BALANCEC_DATAbytes long34 = 500 bytes;), CASE WHEN C_CREDIT = 'BC' THEN SUBSTR(C_DATA, 1, 200) ELSE NULL END ASFROM NEW TABLE ( UPDATE CUSTOMER/* Update the warehouse */SET C_BALANCE = C_BALANCE - PAY_C_ID.H_AMOUNT, C_YTD_PAYMENT = C_YTD_PAYMENT + PAY_C_ID.H_AMOUNT, C_PAYMENT_CNT = C_PAYMENT_CNT + SMALLINT( 1 ), C_DATA = CASE WHEN C_CREDIT = 'BC'THEN BAD_CREDIT_PREFIX -- 34END|| SUBSTR( C_DATA, 1, 466 ) -- 466 +ELSE C_DATAWHERE C_W_ID = PAY_C_ID.C_W_IDAND C_D_ID = PAY_C_ID.C_D_IDAND C_ID = PAY_C_ID.C_ID) AS USET ( W_NAME, W_STREET_1, W_STREET_2, W_CITY, W_STATE, W_ZIP );END%= ( SELECT W_NAME, W_STREET_1, W_STREET_2, W_CITY, W_STATE, W_ZIP)FROM OLD TABLE ( UPDATE WAREHOUSE/* Insert into history */INSERTSET W_YTD = W_YTD + PAY_C_ID.H_AMOUNTWHERE W_ID = PAY_C_ID.W_ID) AS UINTO HISTORY ( H_C_ID, H_C_D_ID, H_C_W_ID, H_D_ID, H_W_ID, H_DATA, H_DATE, H_AMOUNT )VALUES ( PAY_C_ID.C_ID, PAY_C_ID.C_D_ID, PAY_C_ID.C_W_ID, PAY_C_ID.D_ID, PAY_C_ID.W_ID, VAR.W_NAME || CHAR( ' ', 4 ) || VAR.D_NAME, VAR.H_DATE, PAY_C_ID.H_AMOUNT);/* Done - return the collected data */RETURN VALUES ( W_STREET_1, W_STREET_2, W_CITY, W_STATE, W_ZIP, D_STREET_1, D_STREET_2, D_CITY, D_STATE, D_ZIP, C_LAST, C_FIRST, C_MIDDLE, C_STREET_1, C_STREET_2, C_CITY, C_STATE, C_ZIP, C_PHONE, C_SINCE, C_CREDIT, C_CREDIT_LIM, C_DISCOUNT, C_BALANCE, C_DATA, H_DATE);---- NEW ORDER--CREATE FUNCTION NEW_OL_ALL( I_ID INT, I_QTY SMALLINT, W_ID INT, SUPP_W_ID INT, O_ID INT, D_ID SMALLINT)RETURNS TABLE( I_PRICE DECIMAL(5,2), I_NAME CHAR(24), I_DATA VARCHAR(50), OL_DIST_INFO CHAR(24), S_DATA VARCHAR(50), S_QUANTITY SMALLINT)SPECIFIC NEW_OL_ALLMODIFIES SQL DATA DETERMINISTIC NO EXTERNAL ACTION LANGUAGE SQL

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!