Implementing Search for Multiple Attributes of a View Object
1 Row Updated by Me in the method applyVCforGlobalSearchEmployees
partial trigger has been added to element what should be updated by clicking on button.
partialTriggers="::b1"
ADF 11g : Implementing Search for Multiple Attributes of a View Object
Implementing Search for Multiple Attributes of a View Object
Original:
https://technology.amis.nl/2011/04/05/adf-11g-implementing-search-for-multiple-attributes-of-a-view-object/
Today I was asked to build a search component that searches a view object for all occurrences of a search string entered by the user. It should look like the ADF Quick Query Component, however, without choice for the attributes to search on. All attributes are search-able. I choose to combine ViewCriteria and custom method on the Application Module. Here is how I did it.
I started with the creation of Default Business Components for the Employees table. Next I created a Bindvariable to represent the value entered by the user.
data:image/s3,"s3://crabby-images/7bc7a/7bc7a61087762f49aa75b2acc9684ff9798bd68b" alt="Implementing Search for Multiple Attributes of a View Object"
After that I created view Criteria containing ‘OR’ conjunctions and ‘CONTAINS’ clauses for all attributes that I need to search on. The image below depicts what the view criteria look like.
data:image/s3,"s3://crabby-images/057e6/057e6c8ca6804927ae5f77a8245211294d0723b4" alt="Implementing Search for Multiple Attributes of a View Object"
Final part in the ADF-BC project is to create a custom method on the Application Module to apply view criteria to the view object and to apply the user entered value to the bind variable.
public void applyVCforGlobalSearchEmployees(String theString){
ViewObjectImpl vo = getEmployeesView1();
ViewCriteria vc = vo.getViewCriteria("EmployeesViewCriteria");
vc.resetCriteria();
VariableValueManager vvm = vc.ensureVariableManager();
vvm.setVariableValue("globalSearchString", theString);
vo.applyViewCriteria(vc,true);
vo.executeQuery();
}
Publish this method to the client so we can use it to search.
data:image/s3,"s3://crabby-images/46002/4600227ac9246ded61e2dc92e161e751609e4425" alt="Implementing Search for Multiple Attributes of a View Object"
The published method is now ready to be used on the page (assuming you created one). If not, just create a simple page containing a table based on the employees collection. Drop the method as an ADF Parameter form.
data:image/s3,"s3://crabby-images/6f5af/6f5afffea9e047cb23e6daa743df9eed00dccd85" alt="Implementing Search for Multiple Attributes of a View Object"
If all is ok, JDeveloper will take care of the partial triggering to refresh the table after the button has been pressed. For the looks, I added a custom icon to the button,adjusted the labels and prompts and moved to component to a toolbar facet.
data:image/s3,"s3://crabby-images/a11ec/a11ec1e3f857c4a336e30edd6528b1fb42bbc301" alt="Implementing Search for Multiple Attributes of a View Object"