data:image/s3,"s3://crabby-images/60a3c/60a3cbcf31a0393aaa5e7eb6beb5d952bbf72803" alt="Kb4484119"
data:image/s3,"s3://crabby-images/5a37d/5a37dac9f41df95e4994237a6071f0106a39be79" alt="kb4484119 kb4484119"
I when to the link you provided, It talks about KB4484198.
data:image/s3,"s3://crabby-images/b9237/b923747d492cf5d9e14a8fe607bed28612c5b9d7" alt="kb4484119 kb4484119"
In my case I needed to manually rename back to, as I hadn't marked it as as system table when I created it in the past. If your original queries that used the tables are either of poor quality or very complex. But be aware, that using a query instead of a table can lead to non-optimized statements being executed against a backend database in specific cases, especially I tested this with all kinds of tables, including external non-MDB tables (like SQL Server). RemoveWorkaroundForCorruptedQueryIssue() does the reverse actions. In our example, the query would be named "IceCreams" and would execute the SQL "select * from ". It will also create a new query with the original table name, that will select all columns of the renamed table. the table "IceCreams" would be renamed to "IceCreams_Table". lauxjpn/CurruptQueryAccessWorkaroundĪddWorkaroundForCorruptedQueryIssue() will add the suffix "_Table" to all non-system tables, e.g. You can find the latest code on my GitHub repository: Private Function EndsWith(str As String, ending As String) As BooleanĮndsWith = (Right(Trim(UCase(str)), endingLen) = UCase(ending)) "NewTableName" & vbTab & "" & vbTab & "(Query deleted)" QueryDefs.Delete(originalTableName)ĭebug.Print "OldTableName" & vbTab & "" & vbTab & _
data:image/s3,"s3://crabby-images/a1ebb/a1ebbe66bda129c280ea7e638b51181dee88338b" alt="kb4484119 kb4484119"
OriginalTableName = Left(tableDef.Name, Len(tableDef.Name) - Len(WorkaroundTableSuffix))Ĭall.
data:image/s3,"s3://crabby-images/3614c/3614cb90b90ddc397adf24e2001eab054fac4007" alt="kb4484119 kb4484119"
If EndsWith(tableDef.Name, WorkaroundTableSuffix) And Not isSystemTable Then Public Sub RemoveWorkaroundForCorruptedQueryIssue() CreateQueryDef(originalTableName, "select * from ")ĭebug.Print "OldTableName/NewQueryName" & vbTab & "" & vbTab & _ TableDef.Name = tableDef.Name & WorkaroundTableSuffixĬall. If Not EndsWith(tableDef.Name, WorkaroundTableSuffix) And Not isSystemTable Then IsSystemTable = tableDef.Attributes And dbSystemObject Public Sub AddWorkaroundForCorruptedQueryIssue() Private Const WorkaroundTableSuffix As String = "_Table" Use AddWorkaroundForCorruptedQueryIssue() to add the workaround and RemoveWorkaroundForCorruptedQueryIssue() to remove it at any time. As a precaution, backup your database first. Use the following module to automatically implement Microsofts suggested workaround (using a query instead of a table).
data:image/s3,"s3://crabby-images/60a3c/60a3cbcf31a0393aaa5e7eb6beb5d952bbf72803" alt="Kb4484119"