证实的认证:

 

搜狐团体五遍移此文出首页,说

那篇文章不属于知识分享型文章,并且有广告思疑。

正文的确属于分享型文章,而且享受的知识点比别的小说都多很多,看看网上朋友回复“多谢分享”就驾驭是分享型小说了。

 

所谓广告嫌疑,这东西一被扣上,就很难说的清。

本框架从二零零五年就始发表在搜狐,从来更新维护到现行反革命,在这之中是有连接到新型版本是收费,但是仍保留开放很多本子的开源的。

但当下宣告的,都以开源的免费版本,再说,涉及到收费就是广告?ext也有收费版本,出现ext相关文章你咋不说是广告?

win8,wp8你用的windows都是收费的,相关的小说你是或不是也要说广告? 

 

话也不自身说,这么久没写作品,露脸少了,欺负笔者新妇是不?
你再欺负我,欺负作者,笔者。。。。只可以沉默了。

 

前言:

 

好久没写文章了,方今习惯了写腾讯网,发今日头条,皆以140字之内+张图纸,偶尔发一发,也有时在闪存里闪一闪。

早先每一日写博客时,闭上眼也能写的非常短不长,那人长久不写博客时,洛阳第三拖拉机厂再拖也不得不迸出那么点字,正剧的习惯!

 

在开源的那条路上,走过了很久很久,有一些想法,也麻木到没有想法。

每当上园子来,看到开源的连锁小说,作者都会竭力的顶上一顶,然则总会发现上面的评论和介绍,是负面声音一片,除了留给邮箱才能发源码的那种。

现在的一段时间,很少再看到博主会坚持不渝的即便骂声的一连发布或更新开源小说,少但不清除没有。 

脚下就那种现状,各位开源流的博主,依然要负责骂声往前走!大帝保佑你们! 

正文:

 

本次开源 CYQ.Data 数据框架 V4.0
开源版本,具体下载地址:
http://www.cyqdata.com/download/article-detail-426

自个儿对切磋本框架的人选不停提供技术协理,技导。

 

学学本框架,至少你能学到怎么样确实成功多对数据库的支撑,和种种数据库的差别性语法(那一个说帮忙多数据库,只有接口却等你去落成的都以浮云,因为达成过才驾驭,差距性的合作才是最麻烦的,框架的开发者把最费劲的事留下您,却对你说帮忙两种数据库,那是多喜剧的事,有力量完结差别性包容,测度你也有能力写出团结的框架了)。

 

那也将改为您未来编写自个儿的框架的资本,钻探并了然底层的框架有助于你成长为高级人员,获得更增加的待遇。

园子里早就有好多同班参考并学习了源码,编写出属于自个儿特性的框架,您还等待什么?

框架截图:

json 1 

 

现实的翻新记录,在源码里就有了,那里就不重复的又贴一大堆文字出来了。 

 

那里贴一段开源的代码中的Json操作类代码,防止微博工作职员误操作:

 

 internal class JsonHelper
    {
        /// <summary>
        /// 是还是不是中标   
        /// </summary>
        public bool Success
        {
            get
            {
                return count > 0;
            }
        }
        private string errorMsg = “”;
        /// <summary>
        /// 错误提醒音信   
        /// </summary>
        public string ErrorMsg
        {
            get
            {
                return errorMsg;
            }
            set
            {
                errorMsg = value;
            }
        }
        private int count = 0;
        /// <summary>
        /// 总记 
        /// </summary>
        public int Count
        {
            get
            {
                return count;
            }
            set
            {
                count = value;
            }
        }
        private List<string> arrData = new List<string>();

        #region 对象与对象时期分割符
        public void addItemOk()
        {
            arrData.Add(“<br>”);
        }
        #endregion

        #region 在数组里添加key,value
        public void addItem(string name, string value)
        {
            arrData.Add(“\”” + name + “\”:” + “\”” + value + “\””);
        }
        #endregion

        #region 重回组装好的json字符串
        public override string ToString()
        {
            StringBuilder sb = new StringBuilder();
            sb.Append(“{“);
            sb.Append(“\”count\”:\”” + count + “\”,”);
            sb.Append(“\”error\”:\”” + errorMsg + “\”,”);
            sb.Append(“\”success\”:\”” + (Success ? “true” : “”) + “\”,”);
            sb.Append(“\”data\”:[“);

            int index = 0;
            sb.Append(“{“);
            if (arrData.Count <= 0)
            {
                sb.Append(“}]”);
            }
            else
            {
                foreach (string val in arrData)
                {
                    index++;

                    if (val != “<br>”)
                    {
                        sb.Append(val + “,”);
                    }
                    else
                    {
                        sb = sb.Replace(“,”, “”, sb.Length – 1, 1);
                        sb.Append(“},”);
                        if (index < arrData.Count)
                        {
                            sb.Append(“{“);
                        }
                    }

                }
                sb = sb.Replace(“,”, “”, sb.Length – 1, 1);
                sb.Append(“]”);
            }

            sb.Append(“}”);
            return sb.ToString();

        }
        #endregion

        #region 为DataTable扩展拍卖
        public void Fill(MDataTable table)
        {
            if (table == null)
            {
                ErrorMsg = “查询对象为Null”;
                return;
            }
            Count = table.Rows.Count;
            for (int i = 0; i < table.Rows.Count; i++)
            {
                for (int j = 0; j < table.Columns.Count; j++)
                {
                    addItem(table.Columns[j].ColumnName, Convert.ToString(table.Rows[i][j].Value));
                }
                addItemOk();
            }
        }
        public MDataTable Load(string json)
        {
            MDataTable table = new MDataTable(“loadFromJson”);
            if (!string.IsNullOrEmpty(json) && json.Length > 30 && json.StartsWith(“{“) && json.IndexOf(‘,’) > -1 && json.EndsWith(“}”))
            {
                try
                {
                    int start=json.IndexOf(“:[{“) + 2;
                    string data = json.Substring(start, json.LastIndexOf(“]}”) – start);
                    data = data.Replace(“\\}”, “#100#”).Replace(“\\,”, “#101#”).Replace(“\\:,”, “#102#”);
                    bool isOK=false;
                    if (!string.IsNullOrEmpty(data))
                    {
                        string[] items = data.Replace(“{“,string.Empty).Split(‘}’);//分隔每一行
                        string item = string.Empty, key = string.Empty, value = string.Empty;
                        for (int i = 0; i < items.Length; i++)//循环每一行数据
                        {
                            item = items[i].Replace(“#100#”, “\\}”).Trim(‘,’);
                            if (string.IsNullOrEmpty(item))
                            {
                                continue;
                            }
                            string[] keyValues = item.Split(‘,’);

                            string keyValue = string.Empty;
                            if (i == 0)
                            {
                                for (int j = 0; j < keyValues.Length; j++)
                                {
                                    keyValue = keyValues[j].Replace(“#101#”, “\\,”);
                                    key = keyValue.Split(‘:’)[0].Trim(‘\”, ‘\”‘);
                                    table.Columns.Add(key, SqlDbType.NVarChar);
                                }
                                isOK=true;
                               
                            }
                            if (isOK)
                            {
                                MDataRow row = table.NewRow();
                                for (int k = 0; k < keyValues.Length; k++)
                                {
                                    keyValue = keyValues[k].Replace(“#101#”, “\\,”);
                                    if (keyValue.IndexOf(‘:’) > -1)
                                    {
                                        value = keyValue.Substring(keyValue.IndexOf(‘:’)+1).Replace(“#102#”, “\\:”).Trim(‘\”, ‘\”‘);
                                        row[k].Value = value;
                                    }
                                }
                                table.Rows.Add(row);
                            }

                        }
                    }
                }
                catch
                {
                    return table;
                }
            }
            return table;
        }
        #endregion
    }

 

 

本版本为秋色园V2.0和V2.5相应的框架版本,为了拉动国内ASP.NET开源博客更进一步协调,近年来将跳过2.0版本开源秋色园V2.5多用户版本。

 

秋色园连串原理作品网上都很多了,想学学的同窗就不要失去了:http://www.cnblogs.com/cyq1162/archive/2010/12/14/1905776.html

此地也有51cto大赛的参加比赛页面,谢谢路过的对象也顺手扔一票:http://blog.51cto.com/contest2012/2127378 

 

 

相关文章

网站地图xml地图