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

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...

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 ...

Android - Basic Steps (Service)

Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...