Solved

Update field in one table by looking it in second table.

Posted on 2009-05-15
20
256 Views
Last Modified: 2012-05-07
Well there just one problem. the second table may have multiple entries. so consider table A

table A:

ROLLNUMBER   NAME
111                     na
111                     na

TABLE B:

ROLLNUMBER  ALIAS NAME
111                    GM     GAURAV
111                    MAN   GAURAV
111                    GAU   GAURAV


NOW I NEED TO UPDATE NAME IN TABLE A LOOKING IT UP IN TABLE B. INNER JOIN WILL GIVE ME 6 ENTRIES BUT I NEED JUST THE NAME SO AFTER UPDATE I SHOULD HAVE JUST 2 ROWS IN TABLE A.

THANKS



0
Comment
Question by:mandelia
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 12
  • 8
20 Comments
 
LVL 5

Author Comment

by:mandelia
ID: 24396051
Dont worry the names are not not different and even if they are something like  First(name)  will solve my purpose
0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396055
syntax depends on the database product/version you use,
please clarify

note: please do not post with ALL CAPS ON...
that's usually considered shouting...
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396196
right now MS Access.
 
0
Get MongoDB database support online, now!

At Percona’s web store you can order your MongoDB database support needs in minutes. No hassles, no fuss, just pick and click. Pay online with a credit card. Handle your MongoDB database support now!

 
LVL 5

Author Comment

by:mandelia
ID: 24396203
oh ok that was not intentional
 
0
 
LVL 143

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 500 total points
ID: 24396222
what about this
UPDATE TABLEA
  SET NAME = DLOOKUP("NAME", "TABLEB", "ROLLNUMBER = " & ROLLNUMBER)

Open in new window

0
 
LVL 5

Author Comment

by:mandelia
ID: 24396274
thanks for the frist part how do in do this in MS SQL  server 2005.
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396319
moreover is there a query that can do the same on multiple servers
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396324
i mean database independent
0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396362
in sql, this would be:
UPDATE a
  SET Name = b.Name
FROM TABLEA a
 JOIN TableB b
  on B.RollNumber = a.RollNumber

Open in new window

0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396367
in oracle:
UPDATE a
  SET Name = (SELECT b.Name FROM TableB b WHERE B.RollNumber = a.RollNumber and rownum = 1 )
FROM TABLEA a

Open in new window

0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396382
in mysql:
UPDATE TableA a, TableB b
  SET a.Name = b.Name
WHERE B.RollNumber = a.RollNumber

Open in new window

0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396398
>i mean database independent
no way, sorry.

the best is you put that code in a stored procedure, so "all" you have to do to make the application "portable" is to change/adjust the stored procedures ...
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396410
but B.RollNumber = a.RollNumber will return 3 rows
wont it create a problem
 
0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396483
no.
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396608
tried  ....
 
UPDATE [TABLEA]
SET NAMEA = DLOOKUP ("NAMEB","TABLEB". "rollB =" & rollA)
 
as column names in table a are rollA and NameA
and in tableB are nameB and rollB
 
 
It gives me invalid use of '.','!' or '()'. in query expression 'DLOOKUP ("NAMEB","TABLEB". "rollB =" & rollA'.
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396740
i have more than 1M rows so using update and Dlookup in VBA is out of question.
i think it will take a lot of time
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396778
sorry my fault there was a . insteed of , after tableB.
 
It worked
0
 
LVL 5

Author Closing Comment

by:mandelia
ID: 31581933
Brilliant
0
 
LVL 5

Author Comment

by:mandelia
ID: 24396886
The query ran fine but didnot update giving a type conversion error.  All fields here is text any idea what can it be
0
 
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 24396925
> All fields here is text any idea what can it be
UPDATE [TABLEA]
SET NAMEA = DLOOKUP ("NAMEB","TABLEB". "rollB = """ & rollA & """ ") 
  

Open in new window

0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction Hopefully the following mnemonic and, ultimately, the acronym it represents is common place to all those reading: Please Excuse My Dear Aunt Sally (PEMDAS). Briefly, though, PEMDAS is used to signify the order of operations (http://en.…
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
There are cases when e.g. an IT administrator wants to have full access and view into selected mailboxes on Exchange server, directly from his own email account in Outlook or Outlook Web Access. This proves useful when for example administrator want…
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…

617 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question