Ir al contenido principal

MVC 4 - Razor (EntityFramework)

EntityFramework


For MVC 4 
  • Install EntityFramework v5
  • install-package EntityFramework -version 5.0 using the console


Create a Context
  • Create a class in the Model folder that extends from : DbContext


using System.Data.Entity; 

namespace PhotoSharingApplication.Models
{
    public class PhotoSharingContext : DbContext 
    {
        public DbSet<Photo> Photos
        { get; set; }
        public DbSet<Comment> Comments
        { get; set; } 

    }
}



Entity Framework Initializer

  • Create the initializer and create the initials objects

using System; using System.Collections.Generic; using System.Data.Entity; using System.IO; using System.Linq; using System.Web; namespace PhotoSharingApplication.Models { public class PhotoSharingInitializer : DropCreateDatabaseAlways<PhotoSharingContext> { //This method puts sample data into the database protected override void Seed(PhotoSharingContext context) { base.Seed(context); //Create some photos var photos = new List<Photo> { new Photo { Title = "Me standing on top of a mountain", Description = "I was very impressed with myself", UserName = "Fred", PhotoFile = getFileBytes("\\Images\\flower.jpg"), ImageMimeType = "image/jpeg", CreatedDate = DateTime.Today }, new Photo { Title = "My New Adventure Works Bike", Description = "It's the bees knees!", UserName = "Fred", PhotoFile = getFileBytes("\\Images\\orchard.jpg"), ImageMimeType = "image/jpeg", CreatedDate = DateTime.Today }, new Photo { Title = "View from the start line", Description = "I took this photo just before we started over my handle bars.", UserName = "Sue", PhotoFile = getFileBytes("\\Images\\path.jpg"), ImageMimeType = "image/jpeg", CreatedDate = DateTime.Today } }; photos.ForEach(s => context.Photos.Add(s)); context.SaveChanges(); //Create some comments var comments = new List<Comment> { new Comment { PhotoID = 1, UserName = "Bert", Subject = "A Big Mountain", Body = "That looks like a very high mountain you have climbed" }, new Comment { PhotoID = 1, UserName = "Sue", Subject = "So?", Body = "I climbed a mountain that high before breakfast everyday" }, new Comment { PhotoID = 2, UserName = "Fred", Subject = "Jealous", Body = "Wow, that new bike looks great!" } }; comments.ForEach(s => context.Comments.Add(s)); context.SaveChanges(); } //This gets a byte array for a file at the path specified //The path is relative to the route of the web site //It is used to seed images private byte[] getFileBytes(string path) { FileStream fileOnDisk = new FileStream(HttpRuntime.AppDomainAppPath + path, FileMode.Open); byte[] fileBytes; using (BinaryReader br = new BinaryReader(fileOnDisk)) { fileBytes = br.ReadBytes((int)fileOnDisk.Length); } return fileBytes; } } }

  • Global.asax - Add the initializer

protected void Application_Start()
        {
            Database.SetInitializer<PhotoSharingContext>(new PhotoSharingInitializer());
        }


  • Add the connection String in Web.config
The name should be as the Context class

<connectionStrings>
    <add name="PhotoSharingContext"

     connectionString = "Server=tcp:rodrigo.database.windows.net,1433;Initial Catalog=PhotoSharingDB;Persist Security Info=False;User ID=rodrigo;Password=Pa$$w0rd;MultipleActiveResultSets=False;Encrypt=True;TrustServerCertificate=False;Connection Timeout=30;"
     providerName =  
        "System.Data.SqlClient" />
    
  </connectionStrings>



Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...