LINQ to SQL(4):OR设计器

时间:2022-05-03
本文章向大家介绍LINQ to SQL(4):OR设计器,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

在我们使用LINQ to SQL的时候,需要大量的使用OR设计器,虽然我们手工写代码也是完全可以实现的,但是OR设计器是非常强大的工具,我想有了它,没有几个人会去手工写代码,当然了,手动写代码也是必须的,这一篇我就写几个典型的需要手工写代码的情况

打开和关闭复数形式

默认情况下,OR设计器会将数据库对象从服务器资源管理器拖放到OR设计器上的时候,会自动将ies,s结尾修改为单数形式,这样可以更准确的表示实例化的实体类到单个数据记录的事实,但是某些时候,我们可能会不需要这种效果,这样倒是可能会把我们的代码弄混乱,如果需要关闭这种效果,这样做

在VS菜单栏点击“工具”--“选项”,打开数据库工具NODE,点击O/R Designer,然后把“启动”的值更改为False

扩展OR设计器生成的代码

的确,OR设计器为我们做了很多的东西,但是某些时候,我们还是不得不动动键盘,智能方便总有它的缺陷,比如下面这种情况:

比如我们查询数据库的Account表,而我们不需要它的密码列,和最后登陆时间列(假设表中是有这些列的),而在我们直接将一个表拖放到OR设计器中的时候,他模型是添加了这些列的,所以我们可能会使用如下的代码

var queryWithAlias = from u in db.User
                                 select new NewUser{ 用户名 = u.UserName, 姓名 = u.Name, 年龄 = u.Age };

这样,我们就没有一个实体类与之对应了,这种情况下,就需要在原有的xxx.designer.cs类里添加一个实体类与他进行对应(像第一节写的那样),他包含“用户名”,“姓名”,“年龄”等属性,当然了,我们完全也可以在外部声明一个这样的类型,但是这样不光破坏了对象的封装,而且在使用上也增加了复杂度

向实体类中添加验证

验证实体类是指确认输入到数据对象中的值是否符合对象架构内的约束,以及是否符合为应用程序所建立的规则的过程。在将更新发送到基础数据库之前对数据进行验证是一种很好的做法,这样可以减少错误。还可以减少应用程序和数据库之间的潜在往返行程次数

在对实体类中添加验证的时候,有两个不同的阶段,分别是在列值更改过程中验证数据和在事体类更新过程中验证数据,由于 C# 项目不会自动生成事件处理程序,因此您可以使用 IntelliSense 创建列更改分部方法

列更改过程中添加验证:

partial void On列名Changing(COLUMNDATATYPE value)
    {
       throw new System.NotImplementedException();
    }

我们在使用时候,把“列名”更改为需要验证的列名

实体类更新过程中验证:

partial void Update类名(类名 instance)
{
    if (instance.列名 == x)
    {
        string ErrorMessage = "Invalid data!";
        throw new System.Exception(ErrorMessage);
    }
}