I am looking for a way to provide a ListSource to a TDBLookupComboBox in delphi without having an actual table on the database server to draw that list from. The DataField for the Combo Box is a 1 character field that contains a coded value such as ‘A’ = ‘Drivers License’, ‘B’ = ‘Passport’, ‘C’ = ‘Library Card’, etc. That is to say that the table only contains A, B, or C. The application is responsible for Displaying ‘Drivers License’ in the GUI. Normally a database might have a look up table but this database does not and I can not add one. My idea is that the DataSource and ListSource for a DB Look-up control do not have to be the same database, so if it were possible to define a small table in my form that contains the look-up data then I could use that an not require a real database table.
Does anyone know of a delphi component that allows a TDataSet to be defined on a form without having any actual data files behind it?
An alternative solution is to use TComboBox rather than TDBLookupComboBox. Use a TDictionary to define a simple in memory lookup.
You could use TComboBox.Items.AddObject instead of a separate lookup table but you’d have to create a wrapper class to store a char as a TObject or use Chr to convert it to an integer then cast it to TObject but a the above is simpler in my opinion.