• python——常用功能之文本处理


    关于SubSonic3.0插件使用实体进行更新操作时(执行T.Update()或T.Save()),某些列无法进行修改操作的问题处理

      SubSonic3.0插件在创建实体后,对实体进行赋值操作时,为了去除一些不必要更新的字段,减少更新的内容,会将更新内容与默认值进行比较,如果默认值与当前更新的内容相等时,则不提交更新本列,这主要是为新增记录时设置的,因为本列虽然不进行更新,但由于数据库里存在默认值,所以提交后数据库会自动判断使用默认值进行填充。

      比如数据库有表Test,有字段StatusName nvrchar(10), StatusId int,默认值为0,正常新增记录语句为 insert into Test (StatusNam,  StatusId) values('名称', 0);  但由于StatusId有默认值,而提交的值同默认值相等的话,实际新增记录语句为insert into Test (StatusNam) values('名称'); 就可以了。

      而SubSonic3.0插件在做修改操作时,由于没有进行判断当前操作是新增还是修改操作,所以同新增记录操作一视同仁,直接将修改该状态值的操作给过滤了,这些列的值也就无法更新,具体修改如下:

      打开模版文件ActiveRecord.tt,找到下面代码

    复制代码
     View Code

    <#=col.SysType #><#=CheckNullable(col)#> _<#=col.CleanName #>;
    public <#=col.SysType #><#=CheckNullable(col)#> <#=col.CleanName #>
    {
    get { return _<#=col.CleanName #>; }
    set
    {
    if(_<#=col.CleanName #>!=value){
    _<#=col.CleanName #>=value;
    var col=tbl.Columns.SingleOrDefault(x=>x.Name=="<#=col.Name #>");
    if(col!=null){
    if(!_dirtyColumns.Any(x=>x.Name==col.Name) && _isLoaded){
    _dirtyColumns.Add(col);
    }
    }
    OnChanged();
    }
    }
    }

    复制代码

      将它修改为

    复制代码
     View Code

    <#=col.SysType #><#=CheckNullable(col)#> _<#=col.CleanName #>;
    public <#=col.SysType #><#=CheckNullable(col)#> <#=col.CleanName #>
    {
    get { return _<#=col.CleanName #>; }
    set
    {
    if(_<#=col.CleanName #>!=value || _isLoaded){
    _<#=col.CleanName #>=value;
    var col=tbl.Columns.SingleOrDefault(x=>x.Name=="<#=col.Name #>");
    if(col!=null){
    if(!_dirtyColumns.Any(x=>x.Name==col.Name) && _isLoaded){
    _dirtyColumns.Add(col);
    }
    }
    OnChanged();
    }
    }
    }

    复制代码

      修改后生成的代码就会改变为:

      

      将SubSonic3.0插件源码重新生成一下就可以正常使用了。

      本文章为原创内容,转载请保留下面信息。

      发表本编内容,只要主为了和大家共同学习共同进步,有兴趣的朋友可以加加Q群:SubSonic3.0学习群(327360708)或Email给我(1654937#qq.com),大家一起探讨,由于本人工作很繁忙,如果疑问请先留言,回复不及时也请谅解。

      想了解更多SubSonic3.0的相关问题,请观注博客:http://www.cnblogs.com/EmptyFS/

    只有将自己置空,才能装进更多的东西
     
    分类: SubSonic
  • 相关阅读:
    java面试②基础部分
    java面试①整体流程
    Mysql加锁过程详解(6)-数据库隔离级别(2)-通过例子理解事务的4种隔离级别
    Mysql加锁过程详解(6)-数据库隔离级别(1)
    CV3——学习笔记-实战项目(上):如何搭建和训练一个深度学习网络
    CV2——学习笔记-图像分类
    CV1——学习笔记
    思无邪
    C++学习笔记
    操作系统——学习笔记
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3267306.html
Copyright © 2020-2023  润新知