Setup Description

ASP.NET(c#) MVC framework with MYSQL database and Entity Framework. This step by step documentation extract only importants configuration in order to make our application running and start correctly. For advance usage you may find it out on microsoft's and mysql's documentation.

Require Installer

Download all the required installer

  1. Connector/Net is a fully-managed ADO.NET driver for MySQL
  1. MySQL for Visual Studio provides access to MySQL objects and data using Microsoft Visual Studio.
  1. Visual Studio Community Edition 2015(Free)

Create New MVC(C#) Project

Before these step were configured, create new MVC project.

  1. File > New > Project.

  2. From left panel chose Web, and chose ASP.NET Web Application(.NET Framework) from right pane. At the time of writing was using .NET Framework 4.5.2.

  3. Change Name and click OK

  4. New window open(select a template)

  5. Select MVC template at left panel

  6. Click Change Authentication button at right panel

  7. And finally choose No Authentication, and press OK.

  8. Last, press OK again.

  9. These above step may or may not change in future version.

Manage NuGet Dependencies

Once the project successfully finished installed, we need to install 2 dependencies installer into our project. Since this project was planed to use Entity Framework and MySQL, then we need install these two :

  1. For this tutorial, we install EF6. Open nuget package manager. We have 2 options for NuGet package installation as follow :
  • Using Package Manager Console. Find Tools > NuGet Package Manager > Package Manager Console. After clicking on this, new panel will showing up at the buttom of application, from the console we can install directly package using command. Install these 2 package for our project.

    • Entity Framework : Install-Package EntityFramework
    • MySql Data Entity : Install-Package MySql.Data.Entity . After install this, new files should be added under our project directories on references's folder. This directories exist under solution explorer. These two files are MySQL.Data and MySQL.Data.Entity.EF6.
  • Using NuGet Package Manager Searching Window. To open, right click our project name under solution explorer menu, and choose Manage NuGet Package. New windows will open and do searching for these below pacakge inside search Box :

    • Entity Framework(v6.1.3 - at the time of writing), and
    • MySql.Data.Entity(v6.9.9 - at the time of writing)

Manage Web.config with our mysql connection and entity framework

Open web.config file located under our project. You may find this file under solution explorer panel. Copy and paste this setting into web.config before closing tag </configuration>.

<configuration>
..............
..............
  <entityFramework>
      <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
        <parameters>
          <parameter value="mssqllocaldb" />
        </parameters>
      </defaultConnectionFactory>
      <providers>
        <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
      <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.9.9.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider></providers>
    `</entityFramework>
  <system.data>
      <DbProviderFactories>
        <remove invariant="MySql.Data.MySqlClient" />
        <add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.9.9.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />
      </DbProviderFactories>
    </system.data>
</configuration>

Adding database connection(Optional)

From server explored, find Data Connection and right click add connection. You can create MysqlData source from this window.

Adding ADO.NET Entity Data Model

For querying from/to MySQL database, we need to use DbContext class for our DAL(Data Access Layer) to communicate with our POJO(Plain Object) that having fields that react with our database's fields.

  1. Under solution explored, right click on our project's name. Choose Add > New Item

  2. New window open. Choose Data at left pane, and choose ADO.NET Entity Data Model at right pane. And give that a name, this name should react with our table's name in database.

  3. Click ok, and choose Code First from Database

  4. Press next, choose connection we set earlier, and press Next

  5. Select table for our entity context's model, and click Finish

  6. This will aoutomatically added connection string on web.config, if dont, copy and paste below code inside web.config before closing tag </configuration> :

<configuration>
...
  <connectionStrings>
    <add name="localhostJer" connectionString="server=localhost;user id=root;database=test" providerName="MySql.Data.MySqlClient" /></connectionStrings>
....
</configuration>
  1. After finish, there is should be one file created with the name you create before. Move those files into Models directory. And change the namespace to react with the correct Models's namespace. In my case, if i create User model during above step, below code should be created automatically, and the fields of class should match with fields/column in our databse's table :
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity.Spatial;

namespace Cuba2.Models // move to Models's folder, and change the namespace
{   

    [Table("test.user")] // data annotation. Set table's name
    public partial class User
    {
        [Key] // primary key
        public int user_id { get; set; }

        [Required]
        [StringLength(255)]
        public string user_name { get; set; }
    }
}

Adding DAL(Data Access Layer) POCO(Plain Old CLR Object)

This class is a normal java class that extend DbContext's class. This class become a bridge to communicate with Entity Model class that we created before. So we didnt directly call the members of Entity Model Class. To start:

  1. Create new folder under root project call DAL

  2. Create new blank class file name OurTable.cs. And paste this below code :

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web;
using Cuba2.Models;

namespace Cuba2.DAL
{
    public class OurTable : DbContext // extend DbCOntext
    {
        public OurTable() : base("name=localhostJer") { } // name = is connection string define in web.config

        public DbSet<User> Users { get; set; } // this is our set of data communication
    }
}

Calling Context from Controller

Finally this controller call the dbcontext configuration inside Context Class that we created on DAL folder. To test our connection working or not :

  1. Open HomeController

  2. Create new method :

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Cuba2.DAL;
using System.Diagnostics;

....
....

public ActionResult Testing ()
{
    // use using, for auto dispose memory after used
    using (var context = new TableContext()) // call table context we defined earlier
    {
        var customers = context.Users.ToList(); // call user properties. toList() is an entity framework provided to get all users
        foreach (var cust in customers)
        {
            // use Debug for write down output inside output tab/panel
            Debug.WriteLine(cust.user_id + " " + cust.user_name); // finally access the properties
        }

    }

    return View();
}
  1. By this time, when we compile the code and run, we should see the result on Output Tab.