Solved

SQL Update\Set of a field in one table from the same field in a different table.

Posted on 2010-09-14
6
252 Views
Last Modified: 2012-06-21
I have a field that needs to be updated\set in Table.B from same field from Table.A.  This needs to be done with the following conditions.

I will write in kind of a  pseudo code format:

Table.B.DOCO = Table.A.DOCO
    Table.B.REF = "6F"                  
       Table.B.DATE = '09/14/2010'
          Table.A.Line = '1'

If the above finds records the Table.B.REF will need to be populated with Table.A.REF

0
Comment
Question by:SnowLapa
6 Comments
 
LVL 20

Expert Comment

by:Silvers5
ID: 33678219
You can setup a trigger in SQL, when the above conditions are met it will insert the record in table A
0
 
LVL 20

Expert Comment

by:Silvers5
ID: 33678225
0
 
LVL 39

Accepted Solution

by:
BrandonGalderisi earned 200 total points
ID: 33678254
If I understand your requirements this is an update you need to run, not a need to keep them in sync continuously.  If so, this should do the trick.

update b
set ref = a.ref
from tableb b
join tablea a
  on b.doco = a.doco
where b.ref = '6F'
  and b.[date] = '2010-09-14' -- changed to non-ambiguous format
  and a.line = '1'

0
Complete Microsoft Windows PC® & Mac Backup

Backup and recovery solutions to protect all your PCs & Mac– on-premises or in remote locations. Acronis backs up entire PC or Mac with patented reliable disk imaging technology and you will be able to restore workstations to a new, dissimilar hardware in minutes.

 

Author Comment

by:SnowLapa
ID: 33678257
I am not very familiar with triggers and I think the learning curve would be to great.  I am a little more familiar with standard SQL statements.  Something more along those line would be great.
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 33678295
>>I have a field that needs to be updated\set in Table.B from same field from Table.A. <<
Don't.  That is a nighmare.  Use a SELECT instead, somthing like:
SELECT  a.ref, b.Col1, b.Col2, b.Col3, ...

FROM    TableA a

        INNER JOIN TableB b ON a.doco = b.doco

WHERE   a.line = '1'

        AND b.ref = '6F'

        AND b.date = '2010-09-14'

Open in new window

0
 

Author Comment

by:SnowLapa
ID: 33681929
Thank you all for the speedy solutions.  BrandonGalderisi solution did work with just a few tweaks.  

Once again, thank you all......
0

Featured Post

Control application downtime with dependency maps

Visualize the interdependencies between application components better with Applications Manager's automated application discovery and dependency mapping feature. Resolve performance issues faster by quickly isolating problematic components.

Join & Write a Comment

Everyone has problem when going to load data into Data warehouse (EDW). They all need to confirm that data quality is good but they don't no how to proceed. Microsoft has provided new task within SSIS 2008 called "Data Profiler Task". It solve th…
Ever needed a SQL 2008 Database replicated/mirrored/log shipped on another server but you can't take the downtime inflicted by initial snapshot or disconnect while T-logs are restored or mirror applied? You can use SQL Server Initialize from Backup…
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function

759 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

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now