Using Dcount in access vba shows run-time error 3075 - vba

I am working on an access database and I want to get a value by a query in witch I used Dcount statement but it shows run-time error 3075. The following is my query, can anybody help and tells me what's wrong with my query?
strTotalNumber = "Select estaQeza, DCount('[" & Subject & "]', 'UnionQueryPersanalInfo', '[" & Subject & "] <> ''') As TotalCount From tblMain Group By estaQeza"

Related

How can I alleviate 'Run-Time Error 3078' after renaming queries?

Morning! I recently renamed a ton of queries I had in Access, went through the VBA and renamed every reference to those queries too. Now when I attempt to use a form that pulls & populates from those queries, I get a runtime Error 3078: Microsoft Office Access database engine is unable to find the input table or query ‘old query name’.
When I select debug it takes me to a line that reads:
strSQL = "SELECT * FROM qry_'NewQryName'_LineItems_TotalPerYear WHERE (EstimateID = " & EstimateID & " AND YearID >= " & StartYearID & " AND YearID <= " & EndYearID & ")"
Set rs = db.OpenRecordset(strSQL, dbOpenSnapshot)
The new name is in the code but the error says it can't find the old name. Very confused, please help.

Run-time error '3075' VBA: Check if file already exists in table

I gave a piece of code where I am trying to check if a file has already been uploaded to a table. When files are uploaded the name of the file uploaded is put into a column called 'Name_of_report'. I am trying to run the below code and check if the file already exists in 'Table1' which holds all data.
However when I run the below code I get the error: Run-time error '3075': Syntax error (missing operator) in query expression 'Name_of_report' = File1. xlsx (which is the value assigned to the TableName variable)
I know it's a simple fix but I'm very new to VBA and have tried various changes and can't seen to get it working.
An help would be appreciated.
Sub Check_TableExists(TableName As Variant)
If CurrentDb.OpenRecordset("SELECT count(Name_of_Report) FROM Table1 WHERE Name_of_Report =" & TableName & ";").Fields(0) > 0 Then
MsgBox ("Data already exists in table")
End If
Parameters for text type field need apostrophe delimiters.
If CurrentDb.OpenRecordset("SELECT count(Name_of_Report) FROM Table1 WHERE Name_of_Report ='" & TableName & "';").Fields(0) > 0 Then
However, domain aggregate function could accomplish instead of opening recordset.
If DCount("*", "Table1", "Name_of_Report='" & TableName & "'") > 0 Then

Deleting a record from table in MS ACCESS 2010

I am trying to delete records from the subreport that created with multiple tables data.
Below is the code I write for this
CurrentDb.Execute "DELETE FROM StateBudget " & " WHERE S_ID=" & ("SLELECT ID FROM States " & " WHERE State=" & Me.subformStateBudget.Form.Recordset.Fields("State"))
And error appear like this
syntax error (missing operator) in query expression 'S_ID=SELECT ID
FROM States WHERE State=????'.
Check this out
CurrentDb.Execute "DELETE FROM StateBudget WHERE S_ID IN (SELECT ID FROM States WHERE State=" & Me.subformStateBudget.Form.Recordset.Fields("State") & ")"
And by the way You have got misspelling in select, You add that string wrongly. That Bracket before Select should be inside the string and many more.

MS Access SQL query within VBA code

I need a second set of eyes on this SQL query embedded in the VBA code. I'm making an MS Access app that returns a dataset based on the to & from date criteria set by the user in the specific date picker boxes. The sql query that you see actually has been tested statically within MS Access query design view. I tested it with actual dates where you see the Me.from_filter and Me.to_filter. It worked perfectly! If you chose something like from 1/1/2015 to 5/1/2015 it returns columns of all the months you need. Perfect. Now when I embed it in the VBA code and assign it to a control variable, I get the "Run-time error '2342': A RunSQL action requires an argument consisting of an SQL statement." Can someone please eyeball this and tell me what might be wrong?
Option Compare Database
Option Explicit
Dim strSQL As String
Private Sub Command0_Click()
If IsNull(Me.from_filter) Or IsNull(Me.to_filter) Then
MsgBox "You have not entered a start date or end date"
Else
strSQL = "TRANSFORM Sum(dbo_ASSET_HISTORY.MARKET_VALUE) AS SumOfMARKET_VALUE " _
& "SELECT [dbo_FIRM]![NAME] AS [FIRM NAME], dbo_FUND.CUSIP, dbo_FUND.FUND_NAME, dbo_FUND.PRODUCT_NAME " _
& "FROM (dbo_ASSET_HISTORY INNER JOIN dbo_FIRM ON dbo_ASSET_HISTORY.FIRM_ID = dbo_FIRM.FIRM_ID) INNER JOIN dbo_FUND ON dbo_ASSET_HISTORY.FUND = dbo_FUND.FUND " _
& "WHERE (((dbo_FIRM.Name) Like 'Voya F*') And ((dbo_ASSET_HISTORY.PROCESS_DATE) >= #" & Me.from_filter & "# And (dbo_ASSET_HISTORY.PROCESS_DATE) <= #" & Me.to_filter & "#)) " _
& "GROUP BY [dbo_FIRM]![NAME], dbo_FUND.CUSIP, dbo_FUND.FUND_NAME, dbo_FUND.PRODUCT_NAME " _
& "PIVOT [dbo_ASSET_HISTORY]![ASSET_YEAR] & '-' & [dbo_ASSET_HISTORY]![ASSET_MONTH];"
DoCmd.RunSQL (strSQL)
End If
End Sub
RunSQL is for running action queries like update, insert, select into, delete, etc as per Microsoft definition https://msdn.microsoft.com/en-us/library/office/ff194626.aspx , you should probably use OpenQuery or similar to run your query.

Excel ODBC SQL Statement Throwing Error '[ODBC EXCEL Driver] Data Type Mismatch in criteria

The SQL statement below inserts values into a new table, in a new sheet (TempPoints). If I remove the last part of the statement (in bold) the query runs OK however when I add it back in to the statement I receive the following error message; '[ODBC EXCEL Driver] Data Type Mismatch in criteria'.
I have replicated the tables and query in SQLServer and it runs OK and as expected which proves the full statement is OK. Is this a limitation of the Excel ODBC driver??
Thank you in advance.
strSQL = "INSERT INTO [TempPoints$] (REFP, PointItemRef, LoadItemRef, PointDES, Iotype, Subtype, Notes) " & _
"SELECT " & tempref & ", [PointsDB$].ItemRef, [LoadstoPointsDB$].LoadRef, [PointsDB$].PointDES, [PointsDB$].Iotype, [PointsDB$].Subtype, [PointsDB$].Notes " & _
"FROM [LoadsToPointsDB$] INNER JOIN [PointsDB$] ON [LoadsToPointsDB$].PointRef = [PointsDB$].ItemRef " & _
"WHERE [LoadsToPointsDB$].LoadRef = " & moditemref & " AND [PointsDB$].SystemComp = 'Y' " & _
**"AND NOT EXISTS (SELECT * FROM [TempPoints$] WHERE [TempPoints$].PointItemRef = [PointsDB$].ItemRef)"**
Thank you for those that viewed this, but I seem to have found the answer.
There is a previous insert into statement that loads data in the table, once the data was being loaded into it, the table was storing the numbers as text and not integers. After removing the rows and ensuring the format of the columns was set to integer the SQL query began to function as expected.