首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ASP.NET MVC5高级编程——(3)MVC模式的模型

而模型一般有:面向业务的模型对象和面向视图的模型对象。 2 什么是主键属性,什么是外键属性?...首先数据库中主外键的定义: 主键 外键 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 作用: 用来保证数据完整性 用来和其他表建立联系用的...而称ArtistID属性为外键属性(foreign key),因为与模型对应的数据库中,专辑表(Album)和艺术家(Artist)表存在对应的外键关系,即ArtistID是Album表的外键!...模型绑定数据验证:ASP.NET MVC在处理模型绑定时,会处理Model的数据验证。模型绑定的数据验证失败,则Controller的ModelState.IsValid验证值为false。 ?...当绑定引发异常时,使用UpdateModel()方法会直接抛出异常。使用TryUpdateModel()方法,则会在验证成功时返回true,失败或发生异常时返回false: ? ?

4.8K40

Asp.Net Web API 2第十五课——Model Validation(模型验证)

当Web API将该JSON转换成Product实例时,它会根据这些验证注解属性对Product进行验证。...在应用程序的其它层面可能会需要附加验证(例如,数据层可能会强制外键约束)。 {"Id":4, "Name":"Gizmo"} 此处,客户端并未指定Price或Weight的值。...“Under-Posting(递交不足)”:当客户端遗漏了某些属性时,便会发生“Under-posting”。例如,假设客户端发送如下: ? 此时模型的状态是有效的,因为零是这些属性的有效值。...若你的模型具有只读属性,Over-posting会产生问题。...{ get; set; } // Leave out "IsAdmin" // 略去了"IsAdmin" } Handling Validation Errors——处理验证错误 当验证失败时

72820
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ASP.NET Web API编程——模型验证与绑定

    默认赋值 Web API会对客户端未指定的模型属性赋初值。对于int,double等数值类型默认的初值为0,对于字符串或引用类型默认的初值是null。...如果未对属性使用特性加以约束,那么ModelState.IsValid的值就是true,若对这样的属性应用Required特性,那么当客户端为对其赋初值时,验证将无法通过,即ModelState.IsValid...的值为false。...过载 此外当客户端所用实体属性多于服务端时,服务端会忽略多出来的属性,但建议控制器操作(Action)所用参数列表的参数或类属性与客户端所传参数完全匹配。...这样即使操作(Action)参数是简单类型,框架也会从消息体中取值来为参数赋值。当使用FromBody特性时,Web API使用请求的Content-Type标头来选择格式化器。

    3K50

    .NET 云原生架构师训练营(模块二 基础巩固 MVC终结点)--学习笔记

    view=aspnetcore-5.0 什么是模型绑定 控制器和 Razor 页面处理来自 HTTP 请求的数据。例如,路由数据可以提供一个记录键,而发布的表单域可以为模型的属性提供一个值。...view=aspnetcore-5.0 Web 应用负责检查 ModelState.IsValid 并做出相应响应 if (!...ModelState.IsValid) { return Page(); } 模型验证的特性与消息 [CreditCard]:验证属性是否具有信用卡格式。...[Compare]:验证模型中的两个属性是否匹配。 [EmailAddress]:验证属性是否具有电子邮件格式。 [Phone]:验证属性是否具有电话号码格式。...[Url]:验证属性是否具有 URL 格式。 [Remote]:通过在服务器上调用操作方法来验证客户端上的输入。

    2.5K10

    .NET 云原生架构师训练营(模块二 基础巩固 MVC终结点)--学习笔记

    view=aspnetcore-5.0 什么是模型绑定 控制器和 Razor 页面处理来自 HTTP 请求的数据。 例如,路由数据可以提供一个记录键,而发布的表单域可以为模型的属性提供一个值。...view=aspnetcore-5.0 Web 应用负责检查 ModelState.IsValid 并做出相应响应 if (!...ModelState.IsValid) { return Page(); } 模型验证的特性与消息 [CreditCard]:验证属性是否具有信用卡格式。...[Compare]:验证模型中的两个属性是否匹配。 [EmailAddress]:验证属性是否具有电子邮件格式。 [Phone]:验证属性是否具有电话号码格式。...[Url]:验证属性是否具有 URL 格式。 [Remote]:通过在服务器上调用操作方法来验证客户端上的输入。

    2.6K11

    ASP.NET Core 添加统一模型验证处理机制

    一.前言 模型验证自ASP.NET MVC便有提供,我们可以在Model(DTO)的属性上加上数据注解(Data Annotations)特性,在进入Action之前便会根据数据注解,来验证输入的数据是否合法...二.Action过滤器实现统一验证 我们在判断验证状态时一般会在Action里判断ModelState.IsValid是否为true。...public IActionResult Create([FromBody]CreateOrderDto dto) { if(ModelState.IsValid) {...} } 如果我们在每个需要验证的Action里面都写这个判断岂不是太麻烦,我们是否可以在进入所有的Action之前都进行验证,如果错误,就直接返回错误信息,不去执行Action了,当然时可以的...context.ModelState.IsValid) { XcHttpResult result = new XcHttpResult() { Result = false

    1.3K50

    Sequelize 系列教程之一对一模型关系

    当设置外键选项时,Sequelize 将使用设置的参数值: const User = this.sequelize.define('user', {/* attributes */}) const Company...一般来说,外键约束可能会导致一些性能问题。所以,建表时我们一般会去掉约束,同时给外键加一个索引(加速查询),但之后的数据的一致性就需要应用层来保证了。...即通过将外键 userId 设置为 NULL,完成表关系的切除。...`id` = 1; 即通过左外连接在获取 id 为 1 的用户时,同时获取其关联的账号。...在 Sequelize 里面定义关系时,关系的调用方会获得相关联的方法,一般为了两边都能操作,会同时定义双向关系(这里双向关系指的是模型层面,并不会在数据库表中出现两个表都加上外键的情况)。

    8.4K10

    Sentry 开发者贡献指南 - 数据库迁移

    目录 命令 将您的数据库升级到最新 将您的数据库移动到特定的迁移 为迁移生成 SQL 生成迁移 将迁移合并到 master 指南 过滤器 索引 删除列/表 列 表 外键 重命名表 添加列 向列添加 NOT...在这种情况下,首先删除其他表中的外键列,然后返回到此步骤。 通过在列上设置 db_constraint=False,删除此表到其他表的任何数据库级外键约束。...接下来,我们需要删除和 db 级外键约束。...外键 创建外键大多没问题,但是对于像 Project、Group 这样的大/繁忙的表,由于获取锁的困难,它可能会导致问题。您仍然可以创建 Django 级别的外键,而无需创建数据库约束。...为此,请在定义键时设置 db_constraint=False。 重命名表 重命名表很危险,会导致停机。发生这种情况的原因是在部署期间将运行旧/新代码的混合。

    3.6K20

    七天学会ASP.NET MVC (三)——ASP.Net MVC 数据处理

    Get: 当需要获取数据时使用。 Post: 当需要新建一些事物时使用。 Put: 当需要更新数据时使用。 Delete:需要删除数据时使用。...当参数是类时,Model Binder 是如何工作的? 当参数为类,Model Binder将通过检索类所有的属性,将接收的数据与类属性名称比较。...当匹配成功时: 如果接收的值是空,则会将空值分配给属性,如果无法执行空值分配,会设置缺省值,ModelState.IsValid将设置为fasle。...如果空值分配成功,会考虑值是否合法,ModelState.IsValid将设置为fasle。 如果匹配不成功,参数会被设置为缺省值。在本实验中ModelState.IsValid不会受影响。 1....TryUpdateModel是将函数参数与Employee对象保持相同,如果更新失败,ModelState.IsValid会设置为False值。 客户端验证是什么?

    5.3K100

    Asp.NetCore Web开发之输入验证

    在开发中,验证表单数据是很重要的一环,如果对用户输入的数据不加限制,那么当错误的数据提交到后台后,轻则破坏数据的有效性,重则会导致服务器瘫痪,这是很致命的。...该框架默认支持的规则有: 规则名 取值 描述 required true|false 必填字段 email true|false 电子邮件格式 date true|false 日期格式 number true...|false 数字 digits true|false 整数 equalTo #field 输入值必须和 #field 相同 maxlength 数字 最大长度 minlength 数字 最小长度...为"12"的时候,会验证出错。...就是代表一个个PersonData中的属性值,这是外层循环,又因为,验证可能为多个,所以通过第二层循环遍历该属性所有的错误信息,现在来测试一下: 直接输入12,控制台打印结果如下: 方法二(模型类实现

    2K30

    Django模型

    DateField 日期, 参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add表示当对象第一次被创建时自动设置当前时间...外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...下面是另外一个模型,和前面的BookInfo模型通过外键关联起来。...外键:通过使用models.ForeignKey来设置外键,ForeignKey的第一个参数是要关联的模型类名,第二个参数是on_delete。...它的常用值可以如下: CASCADE级联,删除主表数据时连通一起删除外键表中数据 PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据 SET_NULL设置为NULL

    1.9K20

    【愚公系列】2022年01月 Python教学课程 40-Django框架之模型属性详解

    "的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add...,表示允许为空,默认值是False blank 如果为True,则该字段允许为空白,默认值是False db_column 字段的名称,如果未指定,则使用属性的名称 db_index 若值为True,...如果为True, 这个字段在表中必须有唯一值,默认值是False null是数据库范畴的概念,blank是表单验证范畴的 6) 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,...对于外键引用表数据如何处理,在django.db.models中包含了可选常量: CASCADE级联,删除主表数据时连通一起删除外键表中数据 PROTECT保护,通过抛出ProtectedError异常...,来阻止删除主表中被外键应用的数据 SET_NULL设置为NULL,仅在该字段null=True允许为null时可用 SET_DEFAULT设置为默认值,仅在该字段设置了默认值时可用 SET()设置为特定值或者调用特定方法

    1.4K20

    Asp.Net MVC4入门指南(8):给数据模型添加校验器

    在本节中将会给Movie模型添加验证逻辑。并且确保这些验证规则在用户创建或编辑电影时被执行。...Title 和Genre 字段不再可以为 null (即,您必须输入一个值) 并且Rating 字段具有最大长度是 5。 验证属性将指定一个验证行为,这样您可以指定模型中的那个属性需要被强制验证。...例如,下面的代码在调用SaveChanges方法时,将引发异常,因为缺失几个必需的Movie属性值,并且价格为零 (这在有效范围之外)。...它用来为以上两个操作方法来显示初始的form,同时在验证出错时来重新显示视图。 请注意,代码如何使用Html.EditorFor helper 输出为Movie中的每个属性的元素。...有了本节介绍的内容,相信大家已经掌握了给数据模型添加校验器的方法。后面大家在进行MVC开发时,一方面可以运用本节知识,一方面也可以借助一些开发工具。

    4.7K100

    Django模型最佳实践

    ,默认为False blank 后台模型管理验证数据时,是否允许为NULL,默认为False choices 设定字段的选项,各元组中的第一个值是设置在模型上的值,第二值是人类可读的值 db_column...default 字段的默认值 editable 字段在后台模型管理或ModelForm中是否显示,默认为True error_messages 设定字段抛出异常时的默认消息的字典,其中的键包括null...db_constraint:是否为外键创建约束,默认值为True。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...SET_NULL:把外键设置为null,当null属性被设置为True时才能这么做。 SET_DEFAULT:把外键设置为默认值,提供了默认值才能这么做。

    2.3K40
    领券