Solved

Insert multiple records into MS Access database

Posted on 2008-10-03
7
2,102 Views
Last Modified: 2012-05-05
I need to import multiple records from an external database into an MS Access table.  I can't seem to come up with the right syntax for multiple records.

This works for a single record:
INSERT INTO tbl_Sample (field_1, field_2, field_3) VALUES
("one",1,#01/01/2001#);

This results in an error for multiple records:
INSERT INTO tbl_Sample (field_1, field_2, field_3) VALUES
("one",1,#01/01/2001#),
("two",2,#02/02/2002#),
("three",3,#03/03/2003#);
"Missing semicolon (;) at end of SQL statement."

Seems like the second example should work, but it doesn't.  Can't seem to come up with the correct systax.


0
Comment
Question by:PWoodruff
[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
7 Comments
 
LVL 18

Expert Comment

by:jmoss111
ID: 22637990
 INSERT INTO tblSample (field_1, field_2, field_3)  
  SELECT value1, value2, value3
   UNION ALL
   SELECT value1, value2, value3
   UNION ALL

jim
0
 
LVL 7

Expert Comment

by:Norush
ID: 22637996
Try this:
INSERT INTO tbl_Sample  (field_1, field_2, field_3)
	SELECT  "one",1,#01/01/2001#
	UNION
	SELECT  "two",2,#02/02/2002#
	UNION
	SELECT  "three",3,#03/03/2003#

Open in new window

0
 
LVL 84

Accepted Solution

by:
Scott McDaniel (Microsoft Access MVP - EE MVE ) earned 100 total points
ID: 22638005
Unfortunately that won't work. You have to call the INSERT statement separately for each of your records.

However, if you can link the two databases together then you can use a subselect to do this:

INSERT INTO tblSample(Field1,Field2,Field3) SELECT Field1, Field2, Field FROM YourLinkedTable
0
Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

 
LVL 44

Expert Comment

by:GRayL
ID: 22638067
You cannot use that format to insert multiple records, it is for a single record only.  I presume you are linked to the table in the external database.  that being the case use this format:

INSERT INTO tbl_Sample (field_1, field_2, field_3)
SELECT fld1, fld2, fld3 FROM tblLinked
WHERE fld2 BETWEEN 1 AND 3;

BTW try to get into the habit of eliminating underscores or any other special characters including spaces from you table, field, and vba variable names. tblSampe is just as readable as tbl_Sample and much easier to type.

Press Alt+F11 to get to the VBA window, click Help, MS Visual Basic Help, Microsoft Jet SQL Reference, Data Manipulation Language, INSERT INTO Statement for more insight.
0
 

Author Comment

by:PWoodruff
ID: 22638381
I'm not linked to the external database, so the SELECT approach will not work.

A bit more info that I didn't think was germane, but perhaps is is:  The process we will be using is for the keeper of the external database to generate the SQL file on his end and then eMail it to me.  Ideally, I would like to be able to import it directly into MS Access.  Alternatively, I guess he could generate his output data as a .csv file and then I could use Access' Get External Data / Import, but I wanted a more streamlined approach.  Also, there may be the case where he will be exporting multiple records for more than one table into a single file for me to import.  Sure wish Access could import like MySQL!

GRayL:  Thanks for the tip regarding uderscore, etc.  It's hard to break old habits.
0
 
LVL 44

Assisted Solution

by:GRayL
GRayL earned 25 total points
ID: 22638432
Don't forget importing a CSV file can be as simple as a click on a form.  You write the code once and you can use it over, and over, and over...
0
 
LVL 44

Expert Comment

by:GRayL
ID: 22639296
When you get down to trying to decide whether a player has contributed, and you decide on 25 points, - thanks but no thanks.  I'm all or nothing - if we be in the same arena again;-)
0

Featured Post

MIM Survival Guide for Service Desk Managers

Major incidents can send mastered service desk processes into disorder. Systems and tools produce the data needed to resolve these incidents, but your challenge is getting that information to the right people fast. Check out the Survival Guide and begin bringing order to chaos.

Question has a verified solution.

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

A simple tool to export all objects of two Access files as text and compare it with Meld, a free diff tool.
In earlier versions of Windows (XP and before), you could drag a database to the taskbar, where it would appear as a taskbar icon to open that database.  This article shows how to recreate this functionality in Windows 7 through 10.
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
With Microsoft Access, learn how to start a database in different ways and produce different start-up actions allowing you to use a single database to perform multiple tasks. Specify a start-up form through options: Specify an Autoexec macro: Us…

740 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