SQL Problem

SQL
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

Q: I am having difficulty in setting up an update query. The scenario follows:

 File A: Cust# Taxfield File B: CustNo Taxkey 

The basic dilemma is how to update the Taxfield in file A, when the Taxkey in file B equals a certain value. For example:

 If A:Cust# = B:Custno and B:Taxkey = NY540 Change A:Taxfield to NY50 

Here's the SQL statement I have developed thus far:

 Update A set Taxfield = 'NY50' where Cust# = all (select Custno from B where Taxkey = 'NY540') 

This statement ends up selecting the proper records from file B, but not updating file A. Where's my mistake?

A: You should be using the IN predicate instead of the quantified predicate '= all'. The result of the '= all' predicate is true only if the subselect returns no values or the relationship is true for every value returned by the subselect.

In your case, the subselect is returning more than one Custno in file B where Taxkey = 'NY540'. Cust# from file A is not equal to every customer returned; therefore, the predicate is not true.

BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  •  

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: