C#无需第三方插件实现json和table互转
来源:互联网 发布:java.util jar包 编辑:程序博客网 时间:2024/05/21 06:37
C# 数据库查询结果table转化为json字符串,或反向把json字符串转换为DataTable数据集合 以下代码经实践简单可用。
我有几张阿里云幸运券分享给你,用券购买或者升级阿里云相应产品会有特惠惊喜哦!把想要买的产品的幸运券都领走吧!快下手,马上就要抢光了。
转换通用类定义:
using System;using System.Collections.Generic;using System.Collections;using System.Linq;using System.Web;using System.Web.Script.Serialization;using System.Data;using System.Reflection;namespace testcsoft{ public static class jsonObject { #region DataTable 转换为Json 字符串 /// <summary> /// DataTable 对象 转换为Json 字符串 /// </summary> /// <param name="dt"></param> /// <returns></returns> public static string ToJson(this DataTable dt) { JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer(); javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值 ArrayList arrayList = new ArrayList(); foreach (DataRow dataRow in dt.Rows) { Dictionary<string, object> dictionary = new Dictionary<string, object>(); //实例化一个参数集合 foreach (DataColumn dataColumn in dt.Columns) { dictionary.Add(dataColumn.ColumnName, dataRow[dataColumn.ColumnName].ToString()); } arrayList.Add(dictionary); //ArrayList集合中添加键值 } return javaScriptSerializer.Serialize(arrayList); //返回一个json字符串 } #endregion #region Json 字符串 转换为 DataTable数据集合 /// <summary> /// Json 字符串 转换为 DataTable数据集合 /// </summary> /// <param name="json"></param> /// <returns></returns> public static DataTable ToDataTable(this string json) { DataTable dataTable = new DataTable(); //实例化 DataTable result; try { JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer(); javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值 ArrayList arrayList = javaScriptSerializer.Deserialize<ArrayList>(json); if (arrayList.Count > 0) { foreach (Dictionary<string, object> dictionary in arrayList) { if (dictionary.Keys.Count<string>() == 0) { result = dataTable; return result; } if (dataTable.Columns.Count == 0) { foreach (string current in dictionary.Keys) { dataTable.Columns.Add(current, dictionary[current].GetType()); } } DataRow dataRow = dataTable.NewRow(); foreach (string current in dictionary.Keys) { dataRow[current] = dictionary[current]; } dataTable.Rows.Add(dataRow); //循环添加行到DataTable中 } } } catch { } result = dataTable; return result; } #endregion }}
使用方法:
DataTable --> json :
string json = jsonObject.ToJson(ds.Tables[0]);
// 其中 ds.Tables[0] 是数据库查询的表
json --> DataTable :
DataTable dt = jsonObject.ToDataTable(json);
这是测试从数据库获取数据并table和json互转结果
阅读原文
http://click.aliyun.com/m/35120/
阅读全文
0 0
- C#无需第三方插件实现json和table互转
- C#无需第三方插件实现json和table互转
- VS2010 C#中实现在调用第三方ocx控件时,无需手动注册ocx控件
- 无需第三方sdk支持的定位功能实现
- ajax(cors跨域)最简单输出json数据方法,无需第三方框架或代码
- 第三方库-Gson和Fast-json
- 无需第三方置换两个值
- android无需第三方sdk的分享
- 不借助第三方插件利用ScrollView自身delegate实现下拉刷新和上拉加载
- 用cordova插件实现ionic第三方登录,获取信息和分享
- cordova 实现第三方登录及分享,qq,微信,微博,插件的使用和改动
- cordova 实现第三方登录及分享,qq,微信,微博,插件的使用和改动
- 不借助第三方程序 无需ie拨号 自动实现adsl拨号上网【ALLyeSNO】
- Delphi实现MP3 互相转换 WAV (无需任何第三方dll)
- 微信第三方登陆,无需注册一键登录,获取用户信息,PHP实现方法
- 无需第三方软件实现Mac支持ntfs读写的最简单操作
- 无需第三方软件实现Mac支持ntfs读写的最简单操作
- 第三方插件
- 10.1.数字与静态
- kmp算法的优化
- SQL 优化经验总结34条
- POI中设置Excel单元格格式样式(居中,字体,边框等)
- glide设置
- C#无需第三方插件实现json和table互转
- 使用Bootstrap+metisMenu完成简单的后台管理界面
- 大龄程序员如何保持自己的职场竞争力
- 使用 PHPStorm 与 Xdebug 调试 Laravel (一)
- 草稿
- chapter21灰度直方图
- $.ajax 中的contentType
- 大数据为什么对人们来说如此重要?
- 穷举法典例