c# 将数据库中值一次赋给MODEL

2024-01-08 03:48

本文主要是介绍c# 将数据库中值一次赋给MODEL,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 /// <summary>

        /// DataTable中的每一列赋值给model中的同名属性

        /// DataTable中只有一行数据

        /// </summary>

        /// <typeparam name="T">泛型:model的类型</typeparam>

        /// <param name="objmodel">model的实例</param>

        /// <param name="dtInfo">DataTable表</param>

        public static void TableToModel<T>(T objmodel, DataTable dtInfo)

        {

            //获取model的类型

            Type modelType = typeof(T);

 

            //获取model中的属性

            PropertyInfo[] modelpropertys = modelType.GetProperties();

 

            //遍历DataTable的每一列

            for (Int32 i = 0; i < dtInfo.Columns.Count; i++)

            {

                //遍历model的每一个属性

                foreach (PropertyInfo pi in modelpropertys)

                {

                    String name = pi.Name;  //获取属性名称

                    //若model属性名称与表中的列名相同

                    if (name == dtInfo.Columns[i].ColumnName)

                    {

                        object value = null ;

                        //获取表中该列对应的数据

                        if (dtInfo.Columns[i].DataType == typeof(string))

                        {

                            if (dtInfo.Rows[0][i] == System.DBNull.Value)

                                value = Convert.ToString(null);

                            else

                            value = dtInfo.Rows[0][i].ToString();

                        }

                        

                        //判断是否为bool类型

                        if (dtInfo.Columns[i].DataType == typeof(bool))

                        {

 

                            if (dtInfo.Rows[0][i] == System.DBNull.Value)

                                value = Convert.ToBoolean(null);

                            else

                                value = Convert.ToBoolean(dtInfo.Rows[0][i]);

                        }

                        //判断是否为DateTime类型

                        else if (dtInfo.Columns[i].DataType == typeof(DateTime) )

                        {

                            if (dtInfo.Rows[0][i] == System.DBNull.Value)

                                value = Convert.ToDateTime(null);

                            else

                            value = Convert.ToDateTime(dtInfo.Rows[0][i]);

                        }

                        //判断是否为int类型

                        else if (dtInfo.Columns[i].DataType == typeof(int) )

                        {

                            

                            if (dtInfo.Rows[0][i] == System.DBNull.Value)

                                value = Convert.ToInt32(null);

                            else

                            value = Convert.ToInt32(dtInfo.Rows[0][i]);

                        }

                        //判断是否为float类型

                        else if (dtInfo.Columns[i].DataType == typeof(Double) )

                        {

                            

                            

                            if (dtInfo.Rows[0][i] == System.DBNull.Value)

                                value = Convert.ToDouble(null);    

                                //value = float.Parse(null);

                            else

                                value = Convert.ToDouble(dtInfo.Rows[0][i]);

                                //value = float.Parse(dtInfo.Rows[0][i].ToString());

 

                        }

                        //将表中该列下的数据赋值给model中的同名属性

                        modelType.GetProperty(name).SetValue(objmodel, value, null);

                    }

                }

            }

        }

 

 

调用方法TableToModel<Recurrencecs>(Conf.currentPatient.recurrencecs, dtrecurrencecs);

这篇关于c# 将数据库中值一次赋给MODEL的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/582225

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp