数据库模型

这个基本上是浓缩 Jerry Tom博客的内容,作为参考http://www.cnblogs.com/mbailing/archive/2012/07/31/2616779.html

说明以后再写。

城市实体类

public partial class city

{

    public int ID { get; set; }

    [MaxLength(100)]

    [RegularExpression(@"^[a-zA-Z''-'\s]{1,40}$")]

    public string Name { get; set; }

    public string CountryCode { get; set; }

    public string District { get; set; }

    public int Population { get; set; }

    public virtual country country { get; set; }

    //这个field临时添加,并没有在数据库中映射

    [CustomValidation(typeof(BusinessValidations), "DescriptionRules")]

    public string Description { get; set; }

}

国家实体类

public partial class country

   {

       public country()

       {

           this.cities = new List<city>();

       }

 

       public string Code { get; set; }

       public string Name { get; set; }

       public string Continent { get; set; }

       public string Region { get; set; }

       public float SurfaceArea { get; set; }

       public Nullable<short> IndepYear { get; set; }

       public int Population { get; set; }

       public Nullable<float> LifeExpectancy { get; set; }

       public Nullable<float> GNP { get; set; }

       public Nullable<float> GNPOld { get; set; }

       public string LocalName { get; set; }

       public string GovernmentForm { get; set; }

       public string HeadOfState { get; set; }

       public Nullable<int> Capital { get; set; }

       public string Code2 { get; set; }

       public virtual ICollection<city> cities { get; set; }

   }

 

自定义验证类

using System;

using System.Collections.Generic;

using System.ComponentModel.DataAnnotations;

using System.Linq;

using System.Text;

 

namespace EFEntity.Validation

{

    public static class BusinessValidations

    {

        public static ValidationResult DescriptionRules(string value)

        {

            var errors = new System.Text.StringBuilder();

            if (value != null)

            {

                var description = value as string;

                if (description.Contains("!"))

                {

                    errors.AppendLine("Description should not contain '!'.");

                }

                if (description.Contains(":)") || description.Contains(":("))

                {

                    errors.AppendLine("Description should not contain emotions.");

                }

            }

            if (errors.Length > 0)

                return new ValidationResult(errors.ToString());

            else

                return ValidationResult.Success;

        }

    }

}

各种静态方法操作全在Controller.cs文件

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using EFEntity.Models;

 

namespace EFEntity

{

    class Controller

    {

        /// <summary>

        /// 添加一个实体

        /// </summary>

        /// <returns></returns>

        public static int AddEntity()

        {

            using (var context = new worldContext())

            {

                var newCity = new city

                    {

 

                        CountryCode = "CHN",

                        District = "Guangdong",

                        Name = "珠海",

                        Population = 10000000

                    };

                context.cities.Add(newCity);

                return context.SaveChanges();

            }

        }

 

        /// <summary>

        /// 同时添加和修改实体

        /// </summary>

        /// <returns></returns>

        public static int MakeMultipleChanges()

        {

            using (var context = new worldContext())

            {

                var niagaraFalls = new city

                    {

                        Name = "Niagara Falls",

                        CountryCode = "USA",

                        District = "California",

                        Population = 12232

                    };

                context.cities.Add(niagaraFalls);

                var query = (from d in context.cities

                             where d.Name == "广州"

                             select d).First();

 

                query.Name = "惠州";

                return context.SaveChanges();

 

 

            }

        }

 

        /// <summary>

        /// 删除一个实体

        /// </summary>

        /// <returns></returns>

        public static int DeleteCity()

        {

            using (var context = new worldContext())

            {

                var oldCity = (from d in context.cities

                               where d.Name == "珠海"

                               select d).Single();

                context.cities.Remove(oldCity);

                return context.SaveChanges();

            }

        }

 

        /// <summary>

        /// 级联删除一个实体(国家)和它相关联的从表实体(城市)

        /// </summary>

        /// <returns></returns>

        public static int DeleteUsaAndCities()

        {

            using (var context = new worldContext())

            {

                var countryUSA = (from d in context.countries

                                  where d.Name == "United States"

                                  select d).Single();

                context.Entry(countryUSA).Collection(d => d.cities).Load();

                context.countries.Remove(countryUSA);

                return context.SaveChanges();

            }

 

        }

 

        /// <summary>

        /// 找到返回一个实体,找不到添加并返回一个实体

        /// </summary>

        public static void FindOrAddCity()

        {

            using (var context = new worldContext())

            {

 

                var newCity = context.cities.FirstOrDefault(p => p.Name == "湛江");

 

                if (newCity == null)

                {

                    newCity = context.cities.Add(new city

                    {

                        Name = "湛江",

                        CountryCode = "CHN",

                        District = "Guangdong",

                        Population = 100

                    });

                    context.SaveChanges();

                }

 

                Console.WriteLine("增加或找到的城市为:" + newCity.Name);

            }

        }

 

        /// <summary>

        /// 创建从表实体,并依附到主表实体,建立关联。

        /// </summary>

        /// <returns></returns>

        public static int NewRelationData()

        {

            using (var context = new worldContext())

            {

                var newcity = new city

                    {

                        Name = "随便什么城市",

                        CountryCode = "CHN", //这个属性值后来还是变成为ZWE,

                        //说明我们在Country加载后覆盖了这个值。

                        District = "Guangdong",

                        Population = 1231232

                    };

                context.cities.Add(newcity);

 

                var countryChina = (from d in context.countries

                                    where d.Code == "ZWE"

                                    select d).Single();

                countryChina.cities.Add(newcity);

                return context.SaveChanges();

            }

        }

 

        /// <summary>

        /// 修改从表实体的依附关系

        /// </summary>

        /// <returns></returns>

        public static int ChangeRelationData()

        {

            using (var context = new worldContext())

            {

                var oldCity = (from c in context.cities

                               where c.Name == "湛江"

                               select c).Single();

                var oldCountry = (from d in context.countries

                                  where d.Code == "ZWE"

                                  select d).Single();

                oldCity.country = oldCountry;

                return context.SaveChanges();

            }

        }

 

        /// <summary>

        /// 检查修改状态

        /// </summary>

        public static void ManualDetectChanges()

        {

            using (var context = new worldContext())

            {

                context.Configuration.AutoDetectChangesEnabled = false;

                var countryAFG = (from d in context.countries

                                  where d.Name == "Afghanistan"

                                  select d).Single();

                countryAFG.SurfaceArea = 1000000;

                Console.WriteLine("Before DetectChanges: {0}", context.Entry(countryAFG).State);

                context.ChangeTracker.DetectChanges();

                Console.WriteLine("After DetectChanges: {0}", context.Entry(countryAFG).State);

 

            }

        }

 

   

 

        /// <summary>

        /// 验证通用方法

        /// </summary>

        /// <typeparam name="T"></typeparam>

        /// <param name="input"></param>

        public static void ConsoleValidateResult<T>(T input) where T : class

        {

            using (var context = new worldContext())

            {

                if (context.Entry(input).GetValidationResult().IsValid)

                {

                    Console.WriteLine("----Valid 验证通过!");

                }

                else

                {

                    Console.WriteLine("----Invalid 验证不通过!");

                }

            }

        }

 

        /// <summary>

        /// 验证实体

        /// </summary>

        public static void ValidateCity()

        {

            //-------------------------------------

            Console.WriteLine("\n验证最大长度");

            ConsoleValidateResult<city>(

                new city

                    {

                        Name = "3412ieiorjteiwjlkrj0943u5094tiroejiktjfgkjfdklsjgdsfddfgfdgfdlksdfs",

                        CountryCode = "CHN",

                        District = "Guangdong",

                        Population = 122

 

                    });

            //-------------------------------------

            Console.WriteLine("\n验证正则表达式");

            ConsoleValidateResult<city>(

                new city

                    {

                        Name = "BeiJingCity",

                        CountryCode = "CHN",

                        District = "直辖市",

                        Population = 100

                    });

 

            //-------------------------------------

            Console.WriteLine("\n验证自定义的规则,这里是Description不能有某些字符串");

            ConsoleValidateResult<city>(

                new city

                    {

                        Name = "Guangzhou", //这里不能是汉字,要不然通不过正则表达式验证

                        CountryCode = "CHN",

                        District = "Guangdong",

                        Population = 100,

                        Description = "This is the description."

                    });

        }

        

        /// <summary>

        /// 于请求中验证属性(Validating Individual Properties on Demand) 

        /// </summary>

        public static void ValidatePropertyOnDemand()

        {

            var cityItem = new city

                {

                    Name = "Beijing",

                    CountryCode = "CHN",

                    District = "直辖市",

                    Population = 100,

                    Description = "我爱北京天安门,Shit!"

 

                };

            using (var context = new worldContext())

            {

                var errors = context.Entry(cityItem).Property(p => p.Description).GetValidationErrors();

                Console.WriteLine();

                Console.WriteLine("#Description 验证错误; {0}",errors.Count());

            }

        }

    }

}

Entity Framework -- 添加,删除,修改,关系依附,关系摘除,验证操作的更多相关文章

  1. Entity framework 绑定到Datagridview的添加删除修改

    Entity framework 绑定到Datagridview的添加删除修改 using System; using System.Collections.Generic; using System ...

  2. Entity Framework Code First主外键关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  3. 【极力分享】[C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例【转载自https://segmentfault.com/a/1190000004152660】

      [C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例 本文我们来学习一下在Entity Framework中使用Cont ...

  4. [C#/.NET]Entity Framework(EF) Code First 多对多关系的实体增,删,改,查操作全程详细示例

    本文我们来学习一下在Entity Framework中使用Context删除多对多关系的实体是如何来实现的.我们将以一个具体的控制台小实例来了解和学习整个实现Entity Framework 多对多关 ...

  5. SQL语句添加删除修改字段及一些表与字段的基本操作

    用SQL语句添加删除修改字段 1.增加字段     alter table docdsp    add dspcode char(200)2.删除字段     ALTER TABLE table_NA ...

  6. JavaScript学习 - 基础(八) - DOM 节点 添加/删除/修改/属性值操作

    html代码: <!--添加/删除/修改 --> <div id="a1"> <button id="a2" onclick=&q ...

  7. JTree 添加 , 删除, 修改

    package com.swing.demo; import java.awt.BorderLayout; import java.awt.Container; import java.awt.eve ...

  8. 用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等

    用SQL语句添加删除修改字段 1.增加字段 alter table docdsp add dspcode char(200) 2.删除字段 ALTER TABLE table_NAME DROP CO ...

  9. SQL语句添加删除修改字段[sql server 2000/2005]

    用SQL语句添加删除修改字段1.增加字段     alter table docdsp    add dspcodechar(200)2.删除字段     ALTER TABLE table_NAME ...

  10. SQL语句添加删除修改字段

    用SQL语句添加删除修改字段1.增加字段     alter table docdsp    add dspcodechar(200)2.删除字段     ALTER TABLE table_NAME ...

随机推荐

  1. 几校联考——day1题解

    T1 约数的个数(好像不可提交) 如果一个整数a能够整除整数b,那么a叫做b的约数.现在有N(1 <= N <= 100,000)个整数,对于其中的每一个数,请找出它在其余N - 1个整数 ...

  2. 使用Flask+uWsgi的方式部署一个blog网站

    本文参考以下文章:https://www.yukunweb.com/2017/12/ubuntu-nginx-uwsgi-flask-app/ 需要学习的地方 nginx+uwsgi部署flask应用 ...

  3. 基本数据类型:字符串(str)

    一.字符串的定义和创建 字符串是一个有序的字符的集合,用于存储和表示基本的文本信息,' '或'' ''或''' '''中间包含的内容称之为字符串,总之加了引号的字符都被认为是字符串! 创建: > ...

  4. odoo api介绍

    odoo api修饰器介绍与应用 参考文档:https://www.cnblogs.com/kfx2007/p/6093994.html 一.one one的用法主要用于self为单一集合的情况,被o ...

  5. scrapy实例matplotlib脚本下载

    利用scrapy框架实现matplotlib实例脚本批量下载至本地并进行文件夹分类:话不多说上代码: 首先是爬虫代码: import scrapy from scrapy.linkextractors ...

  6. vim学习2-文档编辑

    一.vim重复命令 1.重复执行上次命令 在普通模式下.(小数点)表示重复上一次的命令操作 拷贝测试文件到本地目录 $ cp /etc/protocols . 打开文件进行编辑 $ vim proto ...

  7. 学习笔记——TCP“三次握手”和“四次挥手”,简单介绍

    TCP/IP协议中,TCP协议提供可靠的连接服务,采用“三次握手”建立一个连接. (1)第一次握手:客户端发送SYN包(SYN=j)到服务器,并进入SYN_SEND状态,等待服务器确认. (2)第二次 ...

  8. HDU 4522

    DIJK,最短路,建两个图就好了. #include <cstdlib> #include <cstdio> #include <cstring> #include ...

  9. linux sh 脚本调用外部命令

    参考:http://blog.csdn.net/lhb_blog/article/details/22083649 ------------------------------------------ ...

  10. Android之怎样使用ListView列表视图

    ListView 列表视图创建方法: (1)直接使用ListView 组件创建 (2)让Activity继承ListActivity实现 第一种:在XML中直接使用ListView 组件创建 在val ...