[2 days left] What’s wrong with your cloud strategy? Learn why multicloud solutions matter with Nimble Storage.Register Now


Access and SQL query

Posted on 2009-04-13
Medium Priority
Last Modified: 2013-11-29
i wrote a programme clear all the uncleare address to clear addresses. But i stuck one SQL problem. The data is below
IdLocation      Name      Address                      PC                                      newLocation-ID
45678      Dr.Jeffery      "61,Staffordshare"      NE87RT      
45899      Stevan       "61,Staffordshare"      NE87RT      
56789      Jeffery      "45,Stanton Street"      RT68Y      
67899      Henry      "45,Stanton Street"      RT68Y      
36789      Kornar      "45,Stanton Street"      SE23RT      
46789      Rutherford      "78,Virtusa"                          FER234TY      
47890      Segal      "78,Virtusa Road"                           FER234TY      
88845      Peter      "79,Sommerfield"      RT5TYS      

i have more than one million reccords like that. i need get if 1 ,2,3.. address are eqaul , the first address id location going to be insert into  newlocation-ID field.

can u help me to solve this above issue. i can't do manually becuase huge database with more tahn 1 million records.
Any sQL ideas?
Iam doing with MS Access 2003
Question by:lankapala
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
  • 3
  • 2
LVL 12

Accepted Solution

koutny earned 2000 total points
ID: 24128938
A million of records in an Access db is quite a lot. I wonder what the performance must be like...

But to answer your immediate question, a query like the one below should work. Even though again, it will take a long time to execute such a query. Do make a back up of the db before you run this.

To get the query working you would need to replace tbl_name with the actual name of the table.
Also, the query looks only for total matches between records. Ie. all 3 fields must be equal: Name, Address, and PC. I am sure you can modify it easily if you only want to match the address and postcode for example.

UPDATE tbl_name T1 SET [newlocation-ID] = DMin("IdLocation","tbl_name","Name = '" & Name & "' AND Address = '" & Address & "' AND PC = '" & PC & "'")
WHERE EXISTS (SELECT T2.IdLocation FROM tbl_name T2 WHERE T1.Name = T2.Name AND T1.Address = T2.Address AND T1.PC = T2.PC AND T1.IdLocation <> T2.IdLocation)

Open in new window

LVL 93

Expert Comment

by:Patrick Matthews
ID: 24129986
koutny said:
>>A million of records in an Access db is quite a lot. I wonder what the performance must be like...

Not sure I would agree with you there.  A well-designed Access database can run just fine with millions of
records, and a poorly-designed Access database can perform like an arthritic tortoise with just a few tens
of thousands of rows.

The size of the database has less to do with the performance than other, more important factors such as
fitness of design, proper indexing, and network speed.

Author Comment

ID: 24132151
koutny: your are great. great work,
Moving data to the cloud? Find out if you’re ready

Before moving to the cloud, it is important to carefully define your db needs, plan for the migration & understand prod. environment. This wp explains how to define what you need from a cloud provider, plan for the migration & what putting a cloud solution into practice entails.


Author Closing Comment

ID: 31569438
great work thx

Author Comment

ID: 24132175
hi, most of the coding is working properly , if address are some time equal , but some are partly equal on this time its possible tio use % ?
LVL 12

Expert Comment

ID: 24140324
Hi lankapala,
It would be certainly possible to use a LIKE condition (for which the wildcard is the * character in Access).
But it gets a bit tricky in terms of how to do the comparison. For example should it be a match if eg. the address in one record is fully contained within the address of another record?
Such as
"78,Virtusa" and
"78,Virtusa Road"  

That could be handled using the * wildcard at the end. I suppose that you wouldn't use it at the beginning because "178, Virtusa" and "78, Virtusa" are two different addresses.

So try the modified query below. I have only updated it for the address field, I think you should be able to play with it some more on your own.
However, I have to say that getting rid of duplicates might be tricky and you might have to write some VBA code for this - maybe a simple query won't be enough.
When I cleared up a database which I was given the task of maintaining, I created some code with forms which showed me the potential matches when the match was not clear cut.
UPDATE tbl_name T1 
  SET [newlocation-ID] = DMin("IdLocation","tbl_name","Name = '" & Name & "' AND (Address LIKE '" & Address & "*' OR '" & Address  & "' LIKE (Address + '*') AND PC = '" & PC & "'")
WHERE EXISTS (SELECT T2.IdLocation FROM tbl_name T2 WHERE T1.Name = T2.Name AND 
(T1.Address LIKE (T2.Address + '*') OR T2.Address LIKE (T1.Address + '*'))
AND T1.PC = T2.PC AND T1.IdLocation <> T2.IdLocation)

Open in new window


Featured Post


Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Question has a verified solution.

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

Traditionally, the method to display pictures in Access forms and reports is to first download them from URLs to a folder, record the path in a table and then let the form or report pull the pictures from that folder. But why not let Windows retr…
We live in a world of interfaces like the one in the title picture. VBA also allows to use interfaces which offers a lot of possibilities. This article describes how to use interfaces in VBA and how to work around their bugs.
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

656 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