使用新类型Nullable处理数据库表中null字段

简介:
.net 2.0 中,提供了  Nullable 的范型,通过它,我们可以为基础类型如 int 等赋予 null 的值,这样我们就可以处理 null 值了。

例子代码

  数据表有个字段 updateTimestamp,可以为null值。在实体类中使用如下设置:

 

        private DateTime? _updateTimestamp;

 

      /// <summary>

        /// 文件更新日期

        /// </summary>

        public Nullable<DateTime> UpdateTimestamp

        {

            get { return this._updateTimestamp; }

            set { this._updateTimestamp = value; }

 }

 

       /// <summary>

        /// 从DataReader中加载数据

        /// </summary>

        /// <param name="rdr"></param>

        public void Load(IDataReader rdr)

        {

            if (rdr.Read())

            {

                IsLoaded = true;

                this.FileId = (int)rdr["fileId"];

                if (!rdr["updatetimestamp"].Equals(DBNull.Value))

                {

                    this.UpdateTimestamp = (DateTime)rdr["updatetimestamp"];

                }

                ……

                }

            }

}

 

//保存文件方法

public  abstract int CreateFile(……,,DateTime? updatetimestamp, int downloadCount);

 

获取Nullable字段的值

        this.calDatePublished.SelectedDate = this.file. UpdateTimestamp.Value;

        不能直接使用this.calDatePublished.SelectedDate = this.file. UpdateTimestamp;





本文转自 张善友 51CTO博客,原文链接:http://blog.51cto.com/shanyou/75107,如需转载请自行联系原作者
目录
相关文章
|
8月前
|
SQL Java 数据库连接
updateByPrimaryKeySelective()方法因字段为null导致的更新不成功问题解决办法
为了让这个解决方案更容易融入到现有系统中,其实现应该尽量简单且无缝,避免重复代码,并提高代码复用性。结合上述方法中提供的策略,应可以解决在使用 `updateByPrimaryKeySelective()`方法时因字段为null导致的更新不成功问题。请根据实际业务需求和上下文选择最合适的方案。这样的解决方案能够达到更佳的代码质量和维护性。
606 14
|
12月前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
268 5
|
缓存 数据库 数据安全/隐私保护
Discuz! X 数据库字典详解:DZ各数据表作用及字段含义
我们使用DISCUZ做网站时,有时需要对数据表进行操作,在操作数据表之前,需要对数据表进行了解。下面是DISCUZ 数据库各数据表作用及字段含义详解,方便新手更好的了解DISCUZ数据库。
370 4
|
存储 移动开发 数据库
HTML5 Web IndexedDB 数据库常用数据存储类型
IndexedDB 支持多种数据存储类型,满足复杂数据结构的存储需求。它包括基本数据类型(如 Number、String、Boolean、Date)、对象(简单和嵌套对象)、数组、Blob(用于二进制数据如图像和视频)、ArrayBuffer 和 Typed Arrays(处理二进制数据)、结构化克隆(支持 Map 和 Set 等复杂对象),以及 JSON 数据。尽管不直接支持非序列化数据(如函数和 DOM 节点),但可以通过转换实现存储。开发者应根据具体需求选择合适的数据类型,以优化性能和使用体验。
1038 10
|
SQL 关系型数据库 MySQL
MySQL数据库中给表添加字段并设置备注的脚本编写
通过上述步骤,你可以在MySQL数据库中给表成功添加新字段并为其设置备注。这样的操作对于保持数据库结构的清晰和最新非常重要,同时也帮助团队成员理解数据模型的变化和字段的具体含义。在实际操作中,记得调整脚本以适应具体的数据库和表名称,以及字段的详细规范。
611 8
|
存储 JSON BI
关于建表字段是否该使用not null这个问题你怎么看?
V哥分享了在数据库设计中使用 `NOT NULL` 的重要性及应用场景。关键字段如用户名和邮箱应设为 `NOT NULL` 以确保数据完整性;可选字段如中间名和个人资料图片允许 `NULL` 提供更多灵活性。`NULL` 还可用于表示未知状态,如未发货的订单。外键设计需根据业务逻辑决定是否使用 `NOT NULL`。此外,`NOT NULL` 可优化查询性能,但在扩展性和数据兼容性方面,允许 `NULL` 更具优势。结合业务需求和数据统计,合理使用 `NOT NULL` 可确保数据完整性和灵活性。
333 3
|
JSON 数据库 数据格式
数据库表如果有json字段,该怎么更新
数据库表如果有json字段,该怎么更新
|
SQL 关系型数据库 数据处理
|
SQL 存储 数据库

热门文章

最新文章