ASP.NET MVC4+BootStrap 实战(四)

现在呆惯了外企,觉得跳槽出去都没地方去,在外企请假干什么的方便,而且相对轻松,就是money少了点,但是饭也要吃饱啊。

今天要讲的当然是最后一个按钮了,fix按钮。我们看一下js代码

$("#btnfix").click(function () {
        $.ajax({
            url: "/Home/SolrDataFix?pam=" + new Date().toTimeString(),
            type: "POST",
            datatype: "Html",
            beforeSend: function () {
                $("#divfix").show();
            },
            complete: function () {
                $("#divfix").hide();
            },
            success: function (data) {
                if (data.IsSuccess) {
                    alert("Fixed successfully!");
                }
                else {
                    alert(data.ErrorMsg);
                }
            },
            error: function () {
                alert("Fix失败!");
            }
        });
    });

我们fix完成之后会得到一个json格式的数据,我们根据是否成功弹出提示。

接下来我们看看控制器

public JsonResult SolrDataFix()
        {
            int suc = GRLCBiz.GetInstance().FixSolrData();

            if (suc == 1)
            {
                return Json(new { IsSuccess = true }, JsonRequestBehavior.AllowGet);
            }

            return Json(new { IsSuccess = false, ErrorMsg = "Fix failed!" }, JsonRequestBehavior.AllowGet);
        }

在这里,主要是看Biz层的逻辑。其实之前我讲过Compare的时候用多线程,那么fix的时候也必然要使用多线程。不过,这次我们要使用的是.net4以上版本中的Task,看代码

public int FixSolrData()
        {
            if (this.differenceUserEntityList == null) return -1;

            this.movePosition = 0;
            int threadCount = 0;
            int totalCount = differenceUserEntityList.Count;
            threadCount = totalCount % ConstValues.CONN_ComparePerThread == 0 ? totalCount / ConstValues.CONN_ComparePerThread : totalCount / ConstValues.CONN_ComparePerThread + 1;

            if (threadCount > ConstValues.CONN_FixThreadCount)
            {
                threadCount = ConstValues.CONN_FixThreadCount;
            }

            taskList = new List<Task<int>>();

            for (int i = 0; i < threadCount; i++)
            {
                Task<int> task = Task.Factory.StartNew<int>(() =>
                {
                    return SolrDataFixByThread(i);
                });
                taskList.Add(task);
            }

            Task.WaitAll(taskList.ToArray());
            foreach (var task in taskList)
            {
                if (task.Result == -1) return -1;
                break;
            }

            return 1;
        }

这里也是先计算线程数,然后我们循环开启Task,执行任务,任务是什么呢,就是SolrDataFixByThread方法。这段代码也是等待所有线程结束以后,我去循环结果,发现如果有某一个线程执行失败,我就返回-1。OK,我们看一下SolrDataFixByThread这个方法。

private int SolrDataFixByThread(int threadIndex)
        {
            try
            {
                string[] copyUserDBIDList = null;
                while (this.movePosition < this.differenceUserEntityList.Count)
                {
                    lock (this.differenceUserEntityList)
                    {
                        List<string> userIDList = differenceUserEntityList.Select(d => d.UserNo.Trim()).ToList();
                        if (this.movePosition >= this.differenceUserEntityList.Count)
                        {
                            break;
                        }

                        if (this.movePosition <= this.userEntityList.Count - ConstValues.CONN_ComparePerThread)
                        {
                            copyUserDBIDList = new string[ConstValues.CONN_ComparePerThread];
                            userIDList.CopyTo(this.movePosition, copyUserDBIDList, 0, ConstValues.CONN_ComparePerThread);
                        }
                        else
                        {
                            copyUserDBIDList = new string[userEntityList.Count - this.movePosition];
                            userIDList.CopyTo(this.movePosition, copyUserDBIDList, 0, copyUserDBIDList.Length);
                        }

                        this.movePosition += ConstValues.CONN_ComparePerThread;
                    }
                    return this.SolrDataFixStart(copyUserDBIDList, threadIndex);
                }

                return 1;
            }
            catch (Exception ex)
            {
                LogHelper.WriteExceptionLog(MethodBase.GetCurrentMethod(), ex);
                return -1;
            }
        }

和Compare方法大同小异,在此就不多说了。我们看SolrDataFixStart方法

private int SolrDataFixStart(string[] userIDList, int threadIndex)
        {
            string userIDXml = this.BuildUserIDXml(userIDList);
            List<UserDBEntity> userDBEntityList = GRLCDAL.GetInstance().GetUserEntityListByIDs(userIDXml);

            List<UserSolrEntity> userSolrEntityList = userDBEntityList.Select((userDBEntity, userSolrEntity) =>
            {
                userDBEntity.UserID = userDBEntity.UserID ?? string.Empty;
                userDBEntity.UserName = userDBEntity.UserName ?? string.Empty;

                return new UserSolrEntity()
                {
                    UserNo = userDBEntity.UserID,
                    Age = userDBEntity.Age,
                    IsMarried = userDBEntity.Married == "1",
                    Name = userDBEntity.UserName.Trim()
                };
            }).ToList();

            return SolrHelper.GetInstance().AddEntityList(userSolrEntityList.ToList());
        }

第一句,BuildUserIDXml,如下

private string BuildUserIDXml(string[] userIDList)
        {
            XmlDocument xmlDocument = new XmlDocument();
            XmlNode xmlRoot = xmlDocument.CreateElement("UserIDList");
            foreach (var userID in userIDList)
            {
                XmlElement xmlElement = xmlDocument.CreateElement("UserID");
                xmlElement.InnerText = userID;
                xmlRoot.AppendChild(xmlElement);
            }

            return xmlRoot.OuterXml;
        }

构造了一个很简单的xml格式的数据。然后我们将它传入DAL层的方法GetUserEntityListByIDs

public List<UserDBEntity> GetUserEntityListByIDs(string userIDXml)
        {
            string sqlScript = string.Empty;
            try
            {
                sqlScript = DBScriptManager.GetScript(this.GetType(), "GetUserInfoByIDs");
                SqlParameter[] sqlParameters =
                {
                    new SqlParameter("@UserIDXml",SqlDbType.Xml)
                };

                sqlParameters[0].Value = userIDXml;
                DataSet ds = SqlHelper.ExecuteDataset(ConstValues.CON_DBConnection, CommandType.Text, sqlScript, sqlParameters);

                if (ds != null && ds.Tables.Count > 0)
                {
                    return ds.Tables[0].ToEntityList<UserDBEntity>();
                }

                return new List<UserDBEntity>();
            }
            catch (Exception ex)
            {
                LogHelper.WriteExceptionLog(MethodBase.GetCurrentMethod(), ex);
                return null;
            }
        }

没什么可说的,大家注意,这里这个参数是xml类型的,在SqlServer中,当我们要传递一批数据进行更新时,往往是传入一个实体List进行更新,就可以采用xml的方式传入SP,进行批量处理。OK,我们看一下这个脚本

;WITH UserIDList AS
     (
        SELECT U.C.value(N‘(text())[1]‘,‘CHAR(25)‘) AS UserID
        FROM @UserIDXml.nodes(N‘UserIDList/UserID‘) AS U(C)
     )
     
     SELECT
        A.UseNo,
        ISNULL(B.Name,‘‘) AS Name,
        ISNULL(B.Age,0) AS Age,
        ISNULL(B.Temper,‘‘) AS Married
     FROM Bonus.dbo.[User] A WITH(NOLOCK)
     INNER JOIN Bonus.dbo.UerInfo B WITH(NOLOCK)
        ON A.UseNo = B.UseNo
     WHERE EXISTS(
        SELECT TOP 1 1
        FROM UserIDList C
        WHERE C.UserID = A.UseNo
     )

第一句先解析出数据放入一个临时表UserIDList,大家注意这个临时表只能在紧跟着的后面的语句中使用,而且只能使用一次就销毁了。ok,通过这个脚本,我们就拿到了要同步到Solr的数据,开始同步

同步完成之后,我们看一下Solr数据,linux中的火狐浏览器没有样式

我们还是通过windows浏览

OK,Fix一部分数据之后,对比变成下面的样子

OK,今天就到这里,以后会换个系统讲解。

时间: 2024-10-18 07:52:00

ASP.NET MVC4+BootStrap 实战(四)的相关文章

ASP.NET MVC4+BootStrap 实战(二)

上一篇文章我们讲述了页面初始加载数据的一些东西,本篇我们来讲一下查询按钮和分页按钮.在很久以前我写过一篇ASP.NET MVC4切近实战的文章,有关于分页的代码,本篇我们不采用微软的AJAX框架. 先看一下查询效果,在点击Get按钮之后,会进行AJAX请求. js代码如下 jQuery(document).ready(function () {     setRowBackColor();     $("#btnsearch").click(function () {         

ASP.NET MVC4+BootStrap 实战(十四)

今年没涨工资,心里些许有些不爽.看了吉日嘎拉写的<程序员你伤不起>,觉得自己的经历和老吉比起来,还是相差甚远.心里的那些不爽也渐渐的没了,人一生也就短短的这么几十年,何必把自己搞的不高兴,心情郁闷,要学会自己调节.那些当和尚的,一辈子也就那么回事,开法拉利天天泡妞的也不就那么回事.最终都是一个结局,那就是从哪里来到哪里去.人生来,汲取大自然的各种化学元素保持生命,人死后,将汲取的化学元素再还给大自然.也许被动物吃了,也许被植物吸收了.大家有时间还是要看一下吉日嘎啦的这本书,人家现在可是年薪80

ASP.NET MVC4+BootStrap 实战(七)

连续三年年会中奖,第一年二等奖,价值2600元的魔音耳机,到现在才用了10几次.第二年中了个价值260元的飞利浦烧水壶,到现在还没用.今年中了个飞利浦挂烫机,也没查是多少钱,反正觉得奖项一年不如一年.在此我就给大家上一张年会热图. 男人的肚皮舞,嗨爆全场.好了,废话不多说,我们进入正题吧. 今天我们要说的就是主页面以及用户注册界面,功能做的都比较简单,我们先看一下Index界面. <div id="div_navigation" style="margin-top:10

ASP.NET MVC4+BootStrap 实战(三)

上节我们剩余Compare和Fix按钮没有讲,本节我们就来讲一下Compare按钮的功能,年底了,要开年会了,一个个积极的跟邱少云似得,给员工涨工资的时候能不能也积极点.不说了,说多了都是泪. 还记得我之前写的大数据实战之环境搭建,我们今天主要是拿DB的数据和solr的数据作比较,得出比较结果.首先,先启动centOS,启动tomcat,这样我们才能利用SolrNet调用solr公开的API.关于solr的启动再次我就不再赘述. OK,我们将solr实例启动起来后,用firefox浏览管理界面,

ASP.NET MVC4+BootStrap 实战(六)

最近面试了一个西安电子科技大学刚毕业的,不是计算机系毕业,却喜欢编程.除了书本上的知识以外,其他一窍不通,笔试题答得不错.经验欠佳,编程也只懂书本上的一些例子.本来不打算录用,但是后来聊到高等数学和物理是她学的最好的两门,那必须收下.人家都说了能考上西电,就能证明她的学习能力,我和项目经理也就相信人家了.毕竟当年面试的时候我面试的是南京擎天科技,有个西电的面试的是南京联创,人家和我聊了两句,得知我是二本院校的,人家说了句他同学面试的都是腾讯,阿里,百度,新浪,说完直接放弃面试,我去南京擎天还害怕

[转]ASP.NET MVC4+BootStrap 实战(一)

本文转自:http://leelei.blog.51cto.com/856755/1587301 好久没有写关于web开发的文章了,进到这个公司一直就是winform和Silverlight,实在是没有实战web项目的机会.大D也辞职了,去搞web app了.自己也该闲暇时间多学习学习,每天进步一点点. OK,不多说了,看一下Solution的截图 基本上一看就明白了,控制器调用Biz层,Biz层调用DAL层,DAL层进行数据的CURD.Utility是一些公用的类库.ok,为什么程序集的命名都

ASP.NET MVC4+BootStrap 实战(十)

年过完了,也该收心了.想想过年这几天都是每天睡到12:00,实在是腐化.大家都沉浸在抢红包的喜悦之中. 不说了,今天我们主要看一下新闻链接管理界面.先上图,无图无真相. 上半部分主要是对已经添加的外链接进行修改删除,设置优先级,下半部分是新增外链接网站. 首先我们先看一下上半部分. <div id="div_newsManage" class="panel panel-primary" ng-app="newsLinkManageModule&quo

ASP.NET MVC4+BootStrap 实战(八)

今天西安下雪了,贼冷,我去.今年的年终奖还没发,都快揭不开锅了. 今天的话我们来看一下用户删除和修改,天太冷,先调一下胃口,上图,无图无真相. 看到了吧,新增了选择列,操作列,以及页面最下面的全选,反选,新增,删除按钮. 我们先来看一下全选反选吧,经过修改之后,我们的Table变成如下的代码 <table class="table table-bordered table-striped table-hover" ng-init="load()">   

ASP.NET MVC4+BootStrap 实战(九)

哄孩子睡觉哄到现在,要两个孩子真的是不容易.孩子不睡觉,我没办法写博客.孩子睡着了,我一写就要写到半夜2点.6点起床,6:30骑自行车去上班,呼吸着雾霾,头皮冻得僵硬.到了软件园楼底下,还要排队买胡辣汤,排队上电梯.唉,生活不易. 今天,我们要说的当然是用户信息修改,请看下图. 看到一龙了么,重庆功夫盛典和日本变装拳手战成平手,打裂了日本拳手的眉骨.OK,我们点击铅笔,弹出用户信息修改界面.那么,我们在弹出用户信息修改界面之前,先要给弹出界面的form赋值.那么这一步要怎么做,当然了,是使用an