thandel
asked on
MS Access SQL Syntax
Hi I am trying to use SQL to update a table (tEmailRx) with information from a form. The table is laid out as:
CreateDate - Date
MR - Number (long Int)
RxType - Text
Office - Text
Ws - Text
I am trying to use the following code:
UPDATE tEmailRx tEmailRx.Date = #11-15-2017#, tEmailRx.MR = 126011, tEmailRx.RxType='CL', tEmailRx.Office='WB,tEmail Rx.Ws = Environ$("computername")
But I am getting an error. What am I doing wrong with my syntax? SQL is a very weak link for me - Thanks!
CreateDate - Date
MR - Number (long Int)
RxType - Text
Office - Text
Ws - Text
I am trying to use the following code:
sSQL = "UPDATE tEmailRx tEmailRx.CreateDate = #" & Date & "#, tEmailRx.MR = " & Me.ID & ", tEmailRx.RxType='CL', tEmailRx.Office='" & sOffice & ",tEmailRx.Ws = Environ$(""computername"")"
DoCmd.RunSQL sSQL
Which results in:UPDATE tEmailRx tEmailRx.Date = #11-15-2017#, tEmailRx.MR = 126011, tEmailRx.RxType='CL', tEmailRx.Office='WB,tEmail
But I am getting an error. What am I doing wrong with my syntax? SQL is a very weak link for me - Thanks!
ASKER
Thank you, so silly but there must be a small error as now the error is syntax error missing operator in query expression "WB,tEmail.Rx.Ws = 'Jupiter"
Strange, in the code you have tEmailRx.Ws but the error message says you have tEmail.Rx.Ws.
What happens if you use the field names without the table name in the SET part.
What happens if you use the field names without the table name in the SET part.
sSQL = " UPDATE tEmailRx SET CreateDate = #" & Date & "#, MR = " & Me.ID & ", RxType='CL', Office='" & sOffice & ",Ws = '" & Environ$("computername") & "'"
DoCmd.RunSQL sSQL
ASKER
I modified to this
sSQL = " UPDATE tEmailRx SET tEmailRx.CreateDate = #" & Date & "#, tEmailRx.MR = " & Me.ID & ", tEmailRx.RxType='CL', tEmailRx.Office='" & sOffice & "',tEmailRx.Ws = '" & Environ$("computername") & "'"code]
Not getting any error but nothing is happening to the table.
ASKER
I tried your code similar error
ASKER
oh wait slightly different.... "Wb,Ws = 'Jupiter".
I think there's a missing ' in what I posted.
Try this, I think I fixed it.
Try this, I think I fixed it.
sSQL = " UPDATE tEmailRx SET CreateDate = #" & Date & "#, MR = " & "Me.ID" & ", RxType='CL', Office='" & "sOffice" & "',Ws = '" & Environ$("computername") & "'"
DoCmd.RunSQL sSQL
ASKER
Well now its prompting me for a value of Me.Id
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
ASKER
Is Update correct I want to keep adding a row to the table with this... I can't remember if update is what I need to do that.
ASKER
Ah bingo that worked thanks... but it does seem to only update the first row... I would like to add to the table with each execution
UPDATE is for updating a table not adding to it, If you want to add to it then you need INSERT.
In fact if your UPDATE query had run successfully it might update every record in the table.
In fact if your UPDATE query had run successfully it might update every record in the table.
ASKER
Oh I see, to make a insert would I just change Update to Insert?
Not quite, the syntax is a bit different and there are different types of INSERT.
If you wanted to add a record with the values in your UPDATE query it might look something like this.
If you wanted to add a record with the values in your UPDATE query it might look something like this.
sSQL = " INSERT INTO tEmailRx (CreateDate, MR, RxType, Office, Ws)
sSQL = sSQL & " VALUES (#" & Date & "#, " & Me.ID & ",'CL', '" & sOffice & "','" & Environ$("computername") & "')"
ASKER
OK thanks but trying the code no errors but no updates to the table either
Can you post the rest of your code?
ASKER
yes but not sure what part you need? Its really press the button and the SQL runs.
ASKER
Private Sub RxOpEmail_Click()
sSQL = "INSERT INTO tEmailRx (CreateDate, MR, RxType, Office, Ws)"
sSQL = sSQL & " VALUES (#" & Date & "#, " & Me.ID & ",'CL', '" & sOffice & "','" & Environ$("computername") & "')"
DoCmd.RunSQL sSQL
End Sub
ASKER
I'm sorry it is working! I had the table open and assume it would refresh... even if I clicked on another row but it didn't. When I closed and reopened the table it was visible. I apologize for the over sight.
Open in new window