Modules & VBA :: Changing Record Source On A Form - 2 Different Outcomes Using Same Bit Of Code?
			Apr 28, 2015
				I'm changing a record source on a form when the user clicks a "save" button.
I'm doing this to store a value from the current form in a table that is not part of the default form query.
This works fine.
I have a separate button on my form called "Home", when the user clicks this button it requerys the current form which triggers the before update event to run, this in turn brings up a message box which asks the user if they want to save or not. If they click yes then it runs the SaveButton click() code.
   
For some reason when the user presses the save button and then exits, everything works but if a user presses the “home” button which triggers the save button then it brings up the “2107 The Value you entered doesn’t meet the validation rule defined for the field or control.” Runtime error and stops on the change recordsource command.
   
Why triggering the same code directly from a button or indirectly from a before update event has two different outcomes.
	
	View Replies
  
    
		
ADVERTISEMENT
    	
    	Feb 8, 2005
        
        Hi all,
I have Form F_CashSalesHead with a subform F_CashSalesInvFoot with one-2-many relationship on their tables.  Subform contains a checkbox field that I use to lock the record set (On a command button click it runs one update query to add value 1 to each checkbox to make Enable=False all the records of current invoice on the form). 
One-2-many relation ship is made on InvNum field in both tables. 
When I open F_CashSalesHead form, bcz of some code line I wrote on On Load event of F_CashSalesHead , at the beginning it give massage  how many invoices are pending to lock and would you like to see. If click Yes to see list, it opens a small form that called F_Count_Unlocked_Invoices showing invoice numbers and unmarked checkbox which is pending to lock. This small form is based on following query,
SELECT DISTINCTROW T_CashSalesInvFoot.InvNum, T_CashSalesInvFoot.CashSalesCustomerName, Sum(T_CashSalesInvFoot.Lock_Cash_Inv) AS [Sum Of Lock_Cash_Inv]
FROM T_CashSalesInvFoot
GROUP BY T_CashSalesInvFoot.InvNum, T_CashSalesInvFoot.CashSalesCustomerName
HAVING (((Sum(T_CashSalesInvFoot.Lock_Cash_Inv))=0));
This works fine.
What I am looking for is, I want to use the same F_Count_Unlocked_Invoices form for Credit Sales invoice also with the same trick. Because I dont want to create another same form and write code that help to increase size of db.
Can it be done just by changing record source of form F_Count_Unlocked_Invoices? Or what is the way to do it?
With kind regards,
Ashfaque
	View 2 Replies
    View Related
  
    
	
    	
    	Mar 25, 2005
        
        Hello,  I have a form with a subform.  I want to change the record source on the subform during an OnClick event.  I am not sure what I'm doing wrong, but I get a "object does not support this method" error.  Can anyone help?  Thanks in advance.
	View 1 Replies
    View Related
  
    
	
    	
    	Nov 2, 2014
        
        Can I change the Records Source of a subform from within that subform and do a requery to have a different set of records displayed'
  
 I want to be able to refine the records displayed in the subform
	View 8 Replies
    View Related
  
    
	
    	
    	Nov 4, 2013
        
        My form has a Record Source of qry_Profile, it is a query that shows the user the records of the dogs that they currently own.  I want to put a button in the form footer to allow the user to show the records of all the dogs that they have ever owned.
So my question is how do I change the record source with vb.
	View 1 Replies
    View Related
  
    
	
    	
    	Oct 24, 2012
        
        I have created a system consisting of a data entry form etc. It was originally connected to one record source exported from a sharepoint site.I had to add a field to the sharepoint site and so i created this additional field and re-exported the data and changed the forms record source and all occurences in the code of previous to new record source.
However, this change of record source produces the following error on every single event.The expression On Load you entered as the event property setting produced the following error: member already exists in an object from which this object module derives.
I tried to break the code as soon as it hits the load function to track the error - but it doesn't even run this function so the code is not executing at all.When i connect back to the old record source it works fine.
	View 1 Replies
    View Related
  
    
	
    	
    	Dec 17, 2013
        
        In my Access adp, when I open a certain form (frmVertebrates), the databinding occurs in the Load event for the form, for various reasons. I have not specified any datasource in the form's design view. 
Databinding for frmVertebrates:
Code:
Me.Form.RecordSource = "select * from dbo.vertebrates where catalogID=3"
This works great when just opening the form. However, when opening with a filter from a button on another form it won't work, the form displays all records.
Button code: 
DoCmd.OpenForm frmVertebrates, , , "vertID=123"
Obviously, this makes sense, since the record source is explicitly set in the Load event.
Is there a way to capture the filter "vertID=123" so it can be added to the Form.RecordSource sql?
When breaking in the Load-code and watching the 'form' variable, I can't spot the filter condition anywhere...
	View 4 Replies
    View Related
  
    
	
    	
    	Apr 24, 2014
        
        I have 3 tables; tblProjects, tblTesting, and tblEmployees. 
The issue I'm having is that I've created a form which collects testing information from testers that test a particular project. Each project can have multiple testers. tblProject and tblTesters have a one to many relationship and the form (frmTesting) consists of a main form for project info and a subfrom for testing info. 
For each project tested there are 4 possible outcomes. 1st not all testers have tested to project and that case project status is "InTesting", 2nd all testers pass testing in that case project staus is "Waiting Final Approval", 3rd all  testers fail testing in that case project status is "Maintenance" and last some testers pass and some fail in that case project status is "IPR". 
Here is my code for a button I've placed on the sub form.
Private Sub BtnTest_Click()
 Dim db As DAO.Database
 Dim rsSQL As DAO.Recordset
 Dim intMax As Integer
 Dim strSQL As String
 Dim csSQL As String
 Set db = CurrentDb()
[Code] ....
My select statement for my recordset isn't working and I've tested it by putting a specific project number in the statement and I still only pulling one recordset. 
	View 4 Replies
    View Related
  
    
	
    	
    	Feb 13, 2014
        
        Any method of reading web page source code data.
I am trying to create an event similar to a web query in Excel.
The table in question is not a html table but an asp.net table I think.
	View 3 Replies
    View Related
  
    
	
    	
    	Sep 5, 2014
        
        So I have a form which is showing the current record and you can scroll through these and make modifications to them from the form as opposed to using a table.
The form has the following fields populated from the main table
Customer name (Can appear more than once)
Status
Date
Servers
Positions
In addition it has several buttons for next record, previous record, first & last record, new record, delete record and update record.On this form i have a text box that i want to be able to use to search for a record using the customer name when you press the search button associated with it. I've got some code and it is mostly working but it seems to be moving the text entry cursor to the date box of the record for some reason.
What I want it to do is take the text from the search box and find it and move the form to that record. 
Code:
Private Sub btn_cstmr_srch_DblClick(Cancel As Integer)
On Error GoTo HandleError
    Dim strFindWhat As String
    strFindWhat = Me.txt_cust_search.Value
[code]....
	View 6 Replies
    View Related
  
    
	
    	
    	Sep 4, 2014
        
        I am using a datasheet view with dbl click code to open a form to a selected record. I was able to use pbaldy's code and it worked perfectly.
  
DoCmd.OpenForm "Asset Status", , , "[Project Number] = '" & Me.Project_Number & " ' "
 Then I realized I really want to be able to go to other records after I have gone to this form and tried this:
  
 Dim rs As Object
Dim lngBookmark As Long
 'set variable to the current record
lngBookmark = Me.Project_Number
'open new form
[code]....
 But to no avail.  Project_Number is a text field.
	View 12 Replies
    View Related
  
    
	
    	
    	Mar 28, 2005
        
        I have an application with a form where 20 subforms are used to add data to the same table.  The 20 subforms are used to divide the data being added into categories ( think of a grocery store with categories of "Meat", "cereal', vegitables etc)
I use the same subform (with different names) and change the record source on the formOpen event to change the subforms properties. A portion of the code is shown below.
 
tempRecordSource = "SELECT [tSkills Assessment].Skill, [tSkills Assessment].Scale, [tSkills Assessment].Comments, [tSkills Assessment].AreaOfFocus, [tSkills Assessment].SubSectionTitle " & _
                           "From [tSkills Assessment] WHERE (([tSkills Assessment].SubSectionTitle)=" & Chr(34) & tempSubSectionTitle & Chr(34) & " and ([tSkills Assessment].SkillsAssessmentID)=" & [SkillsAssessmentID] & ") ORDER BY [skillOrder];"
        Me(tempSubFormName).Form.RecordSource = tempRecordSource
 
I use an array to feed the code (which is in a loop) the variables needed to assign the correct properties to all the subforms.
 
And it works great.  Yes I know I could have created 20 different subforms, but in an attempt to keep my application simple I am trying to have less objects.
 
The problem is in my output (the Report).
 
When I try to do the same thing on subreports it doesn't work.  I figured the logic should be the same but the code that corresponds to the form code "Me(tempSubFormName).Form.RecordSource = ..."  doesn't work.  Either the logic is wrong or I am not using the correct event???
 
I have tried every combination I could find on the internet and $300 worth of Access manuals but no luck.  Any ideas?????
	View 12 Replies
    View Related
  
    
	
    	
    	Sep 15, 2004
        
        Is there a way to change the vertical scroll bar position to always be at the top when I move from form to form.  Right now, it will start at the top, but when I move to a different form and back, the vertical scroll bar is positioned in the center.  I turned off the autocenter property of the form and saved it in the desired position, but that doesn't work.  My form is maximized when it opens.  I would greatly appreciate some help.  This has been an annoyance for quite some time now.
	View 1 Replies
    View Related
  
    
	
    	
    	Feb 19, 2014
        
        I'm new to Access and VB but I managed to write parts of what I want access to do.By tweaking a code I found on the internet, I managed to write a small Subroutine that allows the user to click on one of the fields of a record in a report and then Access opens the form on that specific record.*My code goes something like this:*
Code:
Private Sub Edit_Click()
* Dim strWhere As String
* Dim DocName As String
* DocName = "FormName"
* strWhere = "[Field Name]='" & Field & "'"
* DoCmd.OpenForm DocName, acNormal, , strWhere
End Sub
Now I want to get the name of the Table where the record exists.So, let's say when I click on the "Field" it gets the name of the table where the record with that field exists and sets it in a variable.OR even better would be, get the name of the Form where that record exists but I guess that's a little more complicated since the record is directly linked to the table...*
	View 14 Replies
    View Related
  
    
	
    	
    	Sep 11, 2013
        
        I am receiving the No Current Record message, but have been unable to determine the code that generates it.  The database is a system that creates tasks and assigns them to users.  In the header section of the Tasks form are several controls they can use to select Active or Completed tasks, refresh the data, sort by columns, etc.  There are also three other forms (not subforms) that lay on top of the Tasks form to provide additional detail about the current task.  
If they "complete" all their active tasks and click Refresh, all the tasks disappear, as they should, and everything works fine. If they then try to close the form, or click any control in the Tasks header, the No Current Record message pops up. I've put debug stops in every conceivable location, but the message appears to occur before any code is activated.
I did find that I can make the message not occur by commenting out the code that synchronizes one of the associated forms (Notes), but I still don't know what is triggering the message.  Debug stops in Notes yield no results either, and clicking a control in the header of Tasks shouldn't affect Notes.
How to find out what's triggering the message?
	View 5 Replies
    View Related
  
    
	
    	
    	Apr 21, 2015
        
        I need any code or way that whenever any field of a record according to unique ID changed the code must save the changed field name and the current date in a specific field in another table (first field store the ID and the second one detail about changes) with add record mechanism. Suppose I have a table about the information of students with the name std_info and another info_report and when any changes make to the any field of std_info the field number and the unique ID to the table info_report. I want to use this system to record which user make changes to which records.
	View 1 Replies
    View Related
  
    
	
    	
    	Jun 9, 2015
        
        I currently have this set as the forms default recordsource (which works just fine):
Code:
SELECT TOP 5 tblUsers_Phone_Book.EMAIL_ADDRESS, weightedDL('me@mine.com',[EMAIL_ADDRESS]) AS Expr1
And I have this vba to dynamically switch around that email address.
Code:
Private Sub Form_Load()
  Dim intPos As Integer
  Dim strControlName As String
  Dim strValue As String
  Dim sSQL As String
  If Len(Me.OpenArgs) > 0 Then
    ' Position of the pipe
[Code] ....
If I msgbox the sSQL - it shows identical to the default recordsource but I get the error: 
The error message I get is:  
Run-Time error '2580'
The record source 'SELECT TOP 5 tblUsers_Phone_Book.EMAIL_ADDRESS, weightedDL('me@mine.com',[EMAIL_ADDRESS]) AS Expr1' specified on this form or report does not exist.
I tried copying the exact working default sql into the vba and get the same result.
	View 3 Replies
    View Related
  
    
	
    	
    	Jul 14, 2006
        
        A simple question that would probably take me hours to figure out by myself: When I want to change the source of a listbox, fx. when a button is clicked, i use the command 'rowsource ='. But what command do i use to change the source of a textbox...??
Thank you in advance :-)
// JR
	View 5 Replies
    View Related
  
    
	
    	
    	Sep 16, 2013
        
        i have a database with a large number of records. Navigating through the records through a form one by one is a pain, so i want to create a text box where you can enter the ID number of the record, and whichever record has the matching ID number it changes to that specific record. I know that something like this is already apparent at the bottom of Access, but i want my user to do everything within the database itself, as all of the panes are removed whilst being used
	View 11 Replies
    View Related
  
    
	
    	
    	Dec 1, 2006
        
        Hi!
I have an MDB file that points to a postgres database. What I'm trying to do is to redirect it to another datasource. The database is exactly the same, but I just need to point it to a different location. I tried doing this with linked table manager by refreshing the table and enabling the "always prompt for new location". I was able to point to my new location but what happened was my MDB became readonly, I am unable to edit anything after I changed the datasource.
	View 2 Replies
    View Related
  
    
	
    	
    	Jan 26, 2014
        
        I have a form (named Example) to create reports by selecting fields from tables or queries. there is a option box (name is KynkSec) with two options (Table, Query) and a combobox named as KynkTurSec.I want to change the data source of combobox either table or query. By afterupdate, that combobox is requering the listbox "ListKynkAlan" and I can see fields of selected table or query. (That is my dream))Unfortunately I can not do that. Combobox is showing only tables or both of tables and queries. But not only query.
 
Here is str source of my combobox:
 
SELECT MsysObjects.Name, MsysObjects.Type FROM MsysObjects WHERE (((MsysObjects.Type)=1) AND ((Left$([Name],1))<>"~") AND ((Left$([Name],4))<>"Msys")) OR (((MsysObjects.Type)=5) AND ((Left$([Name],1))<>"~") AND ((Left$([Name],4))<>"Msys")) ORDER BY MsysObjects.Name; That is showing both of tables and queries.
 
And I wrote a code for KynkSec option box;
 
Private Sub KynkSec_AfterUpdate()
' Populate rowsource of KynkTurSec
    Dim strSQL As String
On Error GoTo HandleErr
    Select Case KynkTurSec
    Case 1
    strSQL = "SELECT MsysObjects.Name FROM MsysObjects" _
& WHERE(((Left$([Name], 1)) <> "~") And ((MsysObjects.Type) = 1) And ((Left$([Name], 4)) <> "Msys"))
Order BY(MsysObjects.Name)
    Case 2
    strSQL = "SELECT MsysObjects.Name FROM MsysObjects" _
& WHERE(((Left$([Name], 1)) <> "~") And ((MsysObjects.Type) = 5) And ((Left$([Name], 4)) <> "Msys"))
Order BY(MsysObjects.Name)
       Case Else
    End Select
[code]...
 
But this code is not working and giving a warning messsage "Sub or function is not defined"..So How can I change the source of combobox, either table or Query?
	View 3 Replies
    View Related
  
    
	
    	
    	Jul 23, 2014
        
        I am having difficulty with my Access database, when I run a particular query. The query is linked to a table in SQL Server, but I keep getting a "ODBC -Call Failed" error message. After some research I understand I might need to change the ODBC Data Source, but this is something I have never done and am unsure of how to do it so my query will work!
	View 2 Replies
    View Related
  
    
	
    	
    	Nov 16, 2005
        
        I have a main form that has 10 sub forms Each sub forms record source is link to a different Query.
It takes more then a minute to open the form, (because its running the query for all sub forms). So I changed the sub forms source to SELECT * FROM tblTest WHERE false;
I also changed the main form. When the button on the main form is clicked, its adding the following:
Me.SubMySub.Form.RecordSource = "select * from qMyQuery"
Me. SubMySub.Form.Requery
However, after I close the main form, the sub forms record source stays linked to 
SELECT * FROM qMyQuery; 
And will take the same long time again to open the main form.
Does anyone have any solution?
	View 7 Replies
    View Related
  
    
	
    	
    	May 17, 2005
        
        Heya. I hate posting yet another cascading query but I just poured through the first 40 bits and couldn't find something similar.
Basically, I seem to have an errored idea in how to effectively used cascading boxes on a larger form-wide scale.
Basically I have a form with an unbound combobox in the form header: cboSchool
The detail section should only have two fields, StudentID (txtStudentID) and a boolean (bolOT) both of which exist in a specific table source (tblStudents). StudentID is a locked field.
What I would like to do is only have the StudentID's available that are valid for the school. I attempted using a query in the record source that would reference cboSchool but I keep ending up with blank forms. (There's a string of queries that link the schools found in cboSchools to StudentID)
Any ideas?
~Chad
	View 5 Replies
    View Related
  
    
	
    	
    	Jan 10, 2006
        
        Hello,
I'm having a strange problem and was wondering if anyone can help me out. I have a form that is for inputting and modifying data in one table. It used to work when you opened the form you would see x amount of records. Now it's opening to 1 blank record. If you hit filter it fliters like 1700 records and then when you unclick it, you get the entire 10000 records. I thought it had something to do with the Record Source in the properties but when I fixed that it still didn't work. Any ideas?
Thank you!
	View 2 Replies
    View Related
  
    
	
    	
    	Aug 31, 2004
        
        I have 2 forms.  On form1, the record source is a query.  From form2, I need to iterate through the recordset from form1 and perform some action.  How do I access the recordset from form1?
 
Thanks in Advance,
-jnoody
	View 1 Replies
    View Related