Thursday, September 04, 2014

Database Normalization 

This is a brief quick description of database normalization.

Database normalization is the process of organizing information in a relational database into tables to minimize redundancy.

Normalizing a database allows scalability and it is easier to maintain, query and work with.

There are 5 steps to normalize a database, my personal experience is that unless it is absolutely necessary, you are in best shape when you get to step four. Going to step 5 may decrease performance in your database.


There are 5 database normalization steps:

First Normalization Step
Eliminate duplicate columns on tables
Create separate tables for each groups
Identify primary keys for each row

Second Normalization Step
Remove subsets of data that apply to multiple rows of a table
Create  relationships between these new tables using foreign keys

Third Normalization Step
Remove columns that are not dependent on the primary key

Fourth Normalization Step
Every row must have a combination of attributes that can be uniquely identified without any extraneous data - primary key

Fifth Normalization Step
A relation is on Fourth Normalization when there are no rows with any duplicated data

Primary key: is a unique identifier for each record in a table. A primary key can comprise multiple fields, one informational field like email address or social security number,  or it can be generated by the database.

Foreign key: is a field or set of fields in one table that uniquely identifies a row of another number table: car color  or car color and year.

Relationships: a relationship exits between two tables, one has a foreign key referenced to another table.There are 3 relationship types:

  • One to one: one to one relationships can only have one record on each side of the relationship: a car can only have one outside color
  • One to many: one table can have multiple relations to another table: a car can have 2 or more interior colors
  • Many  to  Many: tables can have multiple records related to multiple records on another table: a person can work at multiple companies, you need a third table to relate these kind of relationships


Wednesday, March 19, 2014

Registering .Net Dlls' for use in VB6 32 applications

You have that legacy application that is not willing to go away and you need to use functionality from code you created in .Net.

You need to register the dll for VB6 to be able to find it.

Best thing to do is to create a batch file with the following code:

1) Make the call from you application folder, so you need to move your cursor to that folder
2) Unregister the dll - this is really important as windows registry can get really messy and totally confused if you have multiple versions of the same dll
3) Register the new dll. NOTE: Use the /codebase switch otherwise it just won't happen

Here is the batch file code:

cd C:\Program Files\YourApplication\
C:\windows\microsoft.net\framework\v2.0.50727\Regasm.exe /u YourNewcode.dll
C:\windows\microsoft.net\framework\v2.0.50727\Regasm.exe ReportLogic.dll /codebase

If your application is used by multiple users, you can add code to run the batch file when users load your application.

.Net Fundamentals - Generic Collections - ArraList - List


The .Net Framework collection provides data structures to store and manipulate collections of items as part of the System.Collections namespace.

Array lists are used to store a bunch of items together, you can store items of different data types or items of the same type:

To create a list of items of the same type in C#:
   ArrayList EndOfQuarterList = new ArrayList();
 
  EndOfQuarterList .Add("March");
  EndOfQuarterList .Add("June");
  EndOfQuarterList .Add("September");
  EndOfQuarterList .Add("December");

To create a list of items of different types in VB:

   Dim MixAndMatch as ArrayList = new ArrayList()

  MixAndMatch.Add("First Item")
  MixAndMatch.Add(10)
  MixAndMatch.Add(3.1416)

  But what if we need a more complex ArrayList? you would need to create a Generic List, this object allows easy creation and manipulation of structured data.

  For example, we need to manage financial information at end of every quarter

   C#:
    class QuarterlyInformation
    {
        private string _Name;
        private byte _Month;
        private double _Income;      
        private double _Expenses;
   
        public string Name
        {
            get { return _Name; }
            set { _Name = value; }
        }      

        public byte Month
        {
            get { return _Month; }
            set { _Month = value; }
        }      

        public double Income
        {
            get { return _Income; }
            set { _Income = value; }
        }
   
        public double Expenses
        {
            get { return _Expenses; }
            set { _Expenses = value; }
        }

        public double ProfitAndLoss()
        {
            return _Income - _Expenses;
        }

        public QuarterlyInformation(string Name, byte Month, double Income, double Expenses)
        {
            this.Name = Name;
            this.Month = Month;
            this.Income = Income;
            this.Expenses = Expenses;
        }
    }

     static void Main(string[] args)
        {
            //handle my quarterly information

            List<QuarterlyInformation> Financials = new List<QuarterlyInformation>();

            Financials.Add(new QuarterlyInformation("March", 3, 100, 50));
            Financials.Add(new QuarterlyInformation("June", 6, 500, 250));
            Financials.Add(new QuarterlyInformation("September", 9, 350, 100));
            Financials.Add(new QuarterlyInformation("December", 12, 100, 50));

            foreach (QuarterlyInformation item in Financials)
            {
                Console.WriteLine("Profit and Loss {0}:", item.ProfitAndLoss());
            }
        }
 
     
       To summarize, generic lists are a great tool to create strong typed collections of objects