/// <summary>
/// 将json字符串自动转成dataset,并且自动补全主子关联关系,
/// Guid,FKGuid
/// Author:lijia
/// date:2019-03-28
/// </summary>
/// <param name="schemaName"></param>
/// <param name="tbName">datatable名称</param>
/// <param name="jsonDS">dataset对象</param>
/// <param name="dsJs">json字符串</param>
/// <param name="ListToStringColumn">需要做特殊处理的字段,如字段a:["1","2"]不希望生成单独表</param>
public static void GetDsFromJson(string schemaName, string tbName, DataSet jsonDS, JObject dsJs, List<string> ListToStringColumn)
{
CreateTbByJson(tbName, jsonDS, dsJs, ListToStringColumn);
CreateTbDbByJson(tbName, "rtnTb", "", jsonDS, dsJs, ListToStringColumn);
if (!string.IsNullOrEmpty(schemaName))
{
foreach (DataTable item in jsonDS.Tables)
{
item.TableName = schemaName + "_" + item.TableName;
}
}
}

/// <summary>
/// 根据json组装dataset
/// </summary>
/// <param name="tbName">datatable名称</param>
/// <param name="jsonDS">dataset对象</param>
/// <param name="tbJs">json字符串</param>
/// <param name="ListToStringColumn">需要做特殊处理的字段,如字段a:["1","2"]不希望生成单独表</param>
private static void CreateTbByJson(string tbName, DataSet jsonDS, JObject tbJs, List<string> ListToStringColumn)
{
if (tbName == "") tbName = "rtnTb";
DataTable tb = new DataTable();
tb.TableName = tbName;
if (ListToStringColumn == null)
{
ListToStringColumn = new List<string>();
}
//循环json字符串组装表结构
foreach (var item in tbJs)
{
string fdname = item.Key;
if (ListToStringColumn.Contains(fdname))
{
if (!tb.Columns.Contains(fdname))
{
DataColumn dc = new DataColumn(fdname, typeof(string));
tb.Columns.Add(dc);
}
}
else
{
if (item.Value.Type != JTokenType.Array && item.Value.Type != JTokenType.Object)
{
if (!tb.Columns.Contains(fdname))
{
DataColumn dc = new DataColumn(fdname, typeof(string));
tb.Columns.Add(dc);
}
}
else
{
if (item.Value.Type == JTokenType.Array)
{
JArray rowsJA = item.Value as JArray;
//判断,如果rowsJA第一个元素不是OBJECT,则表示此数组为枚举值数组,则增加表,字段为F1
if (rowsJA.Count > 0 && rowsJA[0].Type != JTokenType.Object && rowsJA[0].Type != JTokenType.Array)
{
if (ListToStringColumn.Count <= 0 || (ListToStringColumn.Count > 0 && !ListToStringColumn.Contains(item.Key)))
{
JArray tmpRowsJA = new JArray();
for (int i = 0; i < rowsJA.Count; i++)
{
JObject tmpRowJO = new JObject();
tmpRowJO.Add("F1", rowsJA[i]);
tmpRowsJA.Add(tmpRowJO);
}
JObject jo = new JObject();
jo.Add(item.Key, tmpRowsJA);
CreateTbByJson(item.Key, jsonDS, jo, ListToStringColumn);
}
}
else
{
foreach (var ArrayItem in item.Value)
{

CreateTbByJson(item.Key, jsonDS, (JObject)ArrayItem, ListToStringColumn);
}
}
}
else
{
CreateTbByJson(item.Key, jsonDS, (JObject)item.Value, ListToStringColumn);
}
}
}
}
if (!tb.Columns.Contains("Guid"))
{
DataColumn dc = new DataColumn("Guid", typeof(string));
tb.Columns.Add(dc);
}
if (!tb.Columns.Contains("Fk_Guid"))
{
DataColumn dc = new DataColumn("Fk_Guid", typeof(string));
tb.Columns.Add(dc);
}
if (!string.IsNullOrEmpty(tbName) && !jsonDS.Tables.Contains(tbName)) //准备表结构
{
jsonDS.Tables.Add(tb);
}
}

/// <summary>
/// 把json数据转换成dataset
/// </summary>
/// <param name="tbName">datatable名称</param>
/// <param name="mtbName">主表名称</param>
/// <param name="strFGuid">Guid唯一键</param>
/// <param name="jsonDS">已经通过json组装好的dataset</param>
/// <param name="tbJs">json数据</param>
/// <param name="ListToStringColumn">需要做特殊处理的字段,如字段a:["1","2"]不希望生成单独表</param>
public static void CreateTbDbByJson(string tbName, string mtbName, string strFGuid, DataSet jsonDS, JObject tbJs, List<string> ListToStringColumn)
{
if (tbName == "") tbName = "rtnTb";
if (jsonDS.Tables.Contains(tbName))
{
DataRow dr = jsonDS.Tables[tbName].NewRow();
string strGuid = System.Guid.NewGuid().ToString();
//strFGuid = strFGuid + "+" + mtbName;
dr["Guid"] = strGuid;
dr["Fk_Guid"] = strFGuid;
foreach (var item in tbJs)
{
string fdname = item.Key;
if (ListToStringColumn.Contains(fdname))
{
dr[fdname] = item.Value.ToString().Replace("[", "").Replace("]", "").Replace(" ", "").Replace("\"", "");
}
else
{
if (item.Value.Type != JTokenType.Array && item.Value.Type != JTokenType.Object)
{
if (!jsonDS.Tables[tbName].Columns.Contains(fdname))
{
DataColumn dc = new DataColumn(fdname, typeof(string));
jsonDS.Tables[tbName].Columns.Add(dc);
}
dr[fdname] = item.Value;
}
else
{
if (item.Value.Type == JTokenType.Array)
{
JArray rowsJA = item.Value as JArray;
//判断,如果rowsJA第一个元素不是OBJECT,则表示此数组为枚举值数组,则增加表,字段为F1
if (rowsJA.Count > 0 && rowsJA[0].Type != JTokenType.Object && rowsJA[0].Type != JTokenType.Array)
{
if (ListToStringColumn.Count <= 0 || (ListToStringColumn.Count > 0 && !ListToStringColumn.Contains(item.Key)))
{
JArray tmpRowsJA = new JArray();
for (int i = 0; i < rowsJA.Count; i++)
{
JObject tmpRowJO = new JObject();
tmpRowJO.Add("F1", rowsJA[i]);
tmpRowsJA.Add(tmpRowJO);
}
rowsJA = tmpRowsJA;
}
}
foreach (var ArrayItem in rowsJA)
{
CreateTbDbByJson(item.Key, tbName, strGuid, jsonDS, (JObject)ArrayItem, ListToStringColumn);
}
}
else
{
CreateTbDbByJson(item.Key, tbName, strGuid, jsonDS, (JObject)item.Value, ListToStringColumn);
}
}
}

}
if (null != dr)
{
jsonDS.Tables[tbName].Rows.Add(dr);
}
}
}

json转dataset的另外一种解析方式自动生成guid强关联的更多相关文章

  1. JSON的三种解析方式

    一.什么是JSON? JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度. JSON就是一串字符串 只不过元素会使用特定 ...

  2. xml中俩种解析方式

    两种解析方式 1.from xml.etree import ElementTree as ET 利用ElementTree模块下的xml方法可以把一个字符串类型的东西转换成Element类,从而利用 ...

  3. Android平台中实现对XML的三种解析方式

    本文介绍在Android平台中实现对XML的三种解析方式. XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能. 在 ...

  4. xml常用四种解析方式优缺点的分析×××××

    xml常用四种解析方式优缺点的分析 博客分类: xml   最近用得到xml的解析方式,于是就翻了翻自己的笔记同时从网上查找了资料,自己在前人的基础上总结了下,贴出来大家分享下. 首先介绍一下xml语 ...

  5. XML 的4种解析方式

    在上一篇博客中,我们介绍了什么是 XML ,http://www.cnblogs.com/ysocean/p/6901008.html,那么这一篇博客我们介绍如何来解析 XML . 部分文档引用:ht ...

  6. 【代码笔记】iOS-json文件的两种解析方式

    一,工程图. 二,代码. #import "ViewController.h" #import "SBJson.h" @interface ViewContro ...

  7. XML解析——Java中XML的四种解析方式

    XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四 ...

  8. XML的两种解析方式

    JDK提供的XML解析方式分为两种:DOM方式和SAX方式DOM:Document Object Model.需要读取整个XML文档,先需要在内存中构架代表整个DOM树的Document对象,可以进行 ...

  9. XML解析——Java中XML的四种解析方式(转载 by 龍清扬)

    XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四 ...

随机推荐

  1. centos 配置虚拟环境

    1.pip install virtualenvwrapper (pip install virtualenv virtualenvwrapper)2.export WORKON_HOME=/home ...

  2. 大白话工厂方法模式(Factory Method)

    目录 简单工厂模式缺陷 简单工厂模式改造 工厂方法模式定义 工厂方法模式结构 工厂方法模式分析 参考文献 简单工厂模式缺陷 大白话简单工厂模式(Simple Factory Pattern)中通过买车 ...

  3. 在服务器上搭建远端git仓库

    推荐使用运行Liunx的机器 请获取root权限后进行下面操作 安装git # 检查是否安装了git如果有版本号就无需再安装 git -v # 安装git sudo apt-get install g ...

  4. Java之GUI编程

    GUI编程 组建 窗口 弹窗 面板 文本框 列表框 按钮 图片 监听事件 鼠标 键盘事件 破解工具 1.简介 GUI的核心技术:Swing AWT 为什么不流行? 界面不美观. 需要jre环境.(没必 ...

  5. 使用font-weight无法调节字体粗细的问题解决

    最近我遇到这样的问题,就是使用font-weight无法调节字体粗细. 据我所知,font-weight是用于调节字体粗细的,可选100.200.300.400(normal).500.600.700 ...

  6. 用Python制作酷炫词云图,原来这么简单!

    一.简介词云图是文本挖掘中用来表征词频的数据可视化图像,通过它可以很直观地展现文本数据中地高频词:! 图1 词云图示例 在Python中有很多可视化框架可以用来制作词云图,如pyecharts,但这些 ...

  7. datagridview 如何显示记载中

    要实现如下效果,有何思路?

  8. Numerical Testing Reportes of A New Conjugate Gradient Projection Method for Convex Constrained Nonlinear Equations

    Numerical Testing Reportes of A New Conjugate Gradient Projection Method for Convex Constrained Nonl ...

  9. 解决jQuery中input 失去焦点之后,不能再获取到焦点

    //编辑过敏史 if(iToolbar == 'editGMS'){ lstype="gms"; var gms=""; if(gmstype=="0 ...

  10. Git 的 .gitignore 配置说明 (C#)

    1.配置语法: 以斜杠“/”开头表示目录: 以星号“*”通配多个字符: 以问号“?”通配单个字符 以方括号“[]”包含单个字符的匹配列表: 以叹号“!”表示不忽略(跟踪)匹配到的文件或目录: 此外,g ...