天天看点

CYQ.Data 数据框架 V4.0 开源版本发布(源码提供下载,秋色园V2.5版本标配框架)

说明的说明:

博客园团队两次移此文出首页,说

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

本文的确属于分享型文章,而且分享的知识点比其它文章都多很多,看看网友回复“谢谢分享”就知道是分享型文章了。

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

本框架从2007年就始发布在博客园,一直更新维护到现在,其中是有过渡到最新版本是收费,但是仍保留开放很多版本的开源的。

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

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

话也不我说,这么久没写文章,露脸少了,欺负我新人是不? 你再欺负我,欺负我,我。。。。只好沉默了。

前言:

好久没写文章了,最近习惯了写微博,发微博,都是140字以内+张图片,偶尔发一发,也偶尔在闪存里闪一闪。

以前天天写博客时,闭上眼也能写的很长很长,这人长久不写博客时,一拖再拖也只能迸出那么点字,悲剧的习惯!

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

每当上园子来,看到开源的相关文章,我都会尽力的顶上一顶,但是总会发现下面的评论,是负面声音一片,除了留下邮箱才能发源码的那种。

之后的一段时间,很少再看到博主会坚持的不怕骂声的继续发布或更新开源文章,少但不排除没有。 

目前就这种现状,各位开源流的博主,还是要顶住骂声往前走!大帝保佑你们! 

正文:

本人对研究本框架的人士持续提供技术支持,技术指导。

学习本框架,至少您能学到如何真正做到多对数据库的支持,和各种数据库的差异性语法(那些说支持多数据库,只有接口却等你去实现的都是浮云,因为实现过才知道,差异性的兼容才是最麻烦的,框架的开发者把最麻烦的事留给你,却对你说支持多种数据库,这是多悲剧的事,有能力实现差异性兼容,估计你也有能力写出自己的框架了)。

这也将成为您往后编写自己的框架的资本,研究并掌握底层的框架有助于你成长为高级人士,获得更丰富的待遇。

园子里已经有很多同学参考并学习了源码,编写出属于自己个性的框架,您还等待什么?

框架截图:

CYQ.Data 数据框架 V4.0 开源版本发布(源码提供下载,秋色园V2.5版本标配框架)

具体的更新记录,在源码里就有了,这里就不重复的又贴一大堆文字出来了。 

这里贴一段开源的代码中的json操作类代码,避免博客园工作人员误操作:

CYQ.Data 数据框架 V4.0 开源版本发布(源码提供下载,秋色园V2.5版本标配框架)

 internal class jsonhelper

    {

        /// <summary>

        /// 是否成功   

        /// </summary>

        public bool success

        {

            get

            {

                return count > 0;

            }

        }

        private string errormsg = "";

        /// 错误提示信息   

        public string errormsg

                return errormsg;

            set

                errormsg = value;

        private int count = 0;

        /// 总记 

        public int count

                return count;

                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 + "\"");

        #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;

            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();

        #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;

    }

CYQ.Data 数据框架 V4.0 开源版本发布(源码提供下载,秋色园V2.5版本标配框架)

本版本为秋色园v2.0和v2.5对应的框架版本,为了促进国内asp.net开源博客更进一步和谐,近期将跳过2.0版本开源秋色园v2.5多用户版本。

版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:

http://www.cnblogs.com/cyq1162/archive/2012/10/31/2747976.html