reflection of database data to an object

I was wondering if anyone knew if there was a way to instantiate an object and then that object use reflection on itself. i.e.

I instantiate an object by calling it like this.

Employee e = new Employee("someID");

then in the process of creating itself employee calls some reflection method to instantiate it's own properties.

Anyone seen this happen?  I've got an idea of how it should be done but just having a hard time figuring it all out.

I am using this article as a basis:

http://www.c-sharpcorner.com/Code/2002/April/ReflectingDataXMLTL004.asp
LVL 3
jayrodAsked:
Who is Participating?

[Product update] Infrastructure Analysis Tool is now available with Business Accounts.Learn More

x
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

purpleblobCommented:
Yes this is be possible below is an example (if this is indeed what you want to do) obviously it seems a little odd using reflection in this manner as when you write the object you'll obviously know the properties etc. , so I assume you've got some clever reason for using reflection for such a process :-)

Anyway, this will work

public class Employee
{
   private int m_Value = 0;

   public int Val
   {
      get { return m_Value; }
      set { m_Value = value; }
   }
   public MyObject(string something)
   {
      Type t = this.GetType();
      PropertyInfo[] pinfo = t.GetProperties();
      t.InvokeMember(pinfo[0].Name, BindingFlags.SetProperty, null, this, new object[]{123});
   }
}

Now if you call this from somewhere else, i.e.

Exmployee obj = new Employee("someID");
int i = obj.Val;

This will assign i the value 123 which was set via reflection within the constructor.

Hope this helps

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
purpleblobCommented:
Whoops, sorry as I was changing the code to reflect your Employee object I forgot to alter the constructor from MyObject to Employee.
jayrodAuthor Commented:
The clever reason is that the properties represent field names in a database. It seems that in order to do this before I would tell the object to get the row corresponding to the object from the database and then manually set each property.  Now this works fine.. but if I changed the database table at all I had to change the code.

I was hoping to find a way to do this dynamically. I asked about this topic a few months back(before I knew anything about reflection) and I eneded up using Hashtables and ArrayLists to represent my data. But this has become way too obscure.

thank you for this code. I'm going to test it out right now :)
jayrodAuthor Commented:
Outstanding!!!!!

Here is the final code. This is a method that will instantiate it's own properties (mind you the properties need to have a Set parameter) with a row from the database.

string sqlString = "select * from nrlfcuDepartments where departmentID = @departmentID";
r1 = SqlHelper.ExecuteReader(connection, CommandType.Text, sqlString, new SqlParameter("@departmentID", this._departmentID));

r1.Read();
if(r1.HasRows)
{

      Type t = this.GetType();
      PropertyInfo[] pinfo = t.GetProperties();

      for(int i=0;i<r1.FieldCount;i++)
      {
            try
            {
                  string name = r1.GetName(i);
                  t.InvokeMember(
                        r1.GetName(i),
                        BindingFlags.Default | BindingFlags.SetProperty,
                        null,
                        this,
                        new object [] { r1.GetValue(i) }
                        );
            }
            catch
            {//Means that a value was null or a fieldName has been changed                                    
            }
      }
}
purpleblobCommented:
Ah, I suspected it might have something to do with initiating your object from a database record :-)

I did see something rather cool on codeproject which used Attributes to say which properties should be set from the database, I think it was this on http://www.codeproject.com/cs/database/dal1.asp I only had a glancing look but you might find it useful/interesting
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
C#

From novice to tech pro — start learning today.