广

ASP.NET

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

    [c#]asp.ent下开发中Tag的开发技巧

    2018-05-04 21:21:22 次阅读 稿源:互联网
    广告
    网站开发常用关键字(tag),一般需要获得最多的被采用的Tag,也就是流行词。
    通常思路是将关键字tag保存到单独表中,然后在其他表中根据一组id进行对多个关键字进行标识。因为一个文章可以选择多个tag,查询的时候颇为麻烦。
    所以我在开发中利用了这样的方法,当然不见得多高明 :),分享下经验。

    将tag直接保存在文章的表中,如Tag字段,tag为“c#”和“.net”,则Tag字段值为“c#/.net”就是依/符号分割tag,这样数据库中保存的是字符串了。单文章显示的时候可以直接分割成数组显示,减少表的关联,提高了效率。
    当需要显示最近流行词的时候。
    查询所有的tag
    select tag from 表
    利用DataReader把输出结果相加起来。然后根据分隔符转化为字符串,剩下的就是对字符串进行排序,根据tag重多少进行。并返回重复的数量,见代码。为方便查看,我都写在了一个aspx页面中了。
    代码如下:

    <%@ Page Language="C#" %>
    <%@ Import Namespace="System.Data" %>
    <%@ Import Namespace="XXXX.BLL" %>
    <%@ Import Namespace="XXXX.Model" %>
    <%@ Import Namespace="XXXX.DBUtility" %>



    <script runat="server">

        protected string stext;
        protected void Page_Load(object sender, EventArgs e)
        {
            StringBuilder sb = new StringBuilder();
            using (System.Data.SqlClient.SqlDataReader rd = XXXX.DBUtility.SqlHelper.ExecuteReader(SqlHelper.ConnectionString, System.Data.CommandType.Text, "Select Kinds + '/' FROM XXX", null))
            {
                while (rd.Read())
                {
                    sb.Append(rd.GetString(0));
                }
            }
            stext = sb.ToString();

            ToArrayBySort(ToArray(stext, '/'));

        }

        

        /// <summary>
        /// 将字符串根据分隔符转化为数组
        /// </summary>
        /// <param name="sourcestring">要转化的字符串</param>
        /// <param name="compart">分隔符</param>
        /// <returns></returns>
        public ArrayList ToArray(string sourcestring, char split)
        {
            CharEnumerator ce = sourcestring.GetEnumerator();
            StringBuilder sb = new StringBuilder();
            ArrayList slist = new ArrayList();

            while (ce.MoveNext())
            {
                if (ce.Current != split)
                {
                    sb.Append(ce.Current);
                }
                else
                {
                    if (string.Empty == sb.ToString()) continue;
                    slist.Add(sb.ToString());
                    sb.Remove(0, sb.ToString().Length);
                }
            }
            return slist;
        }

        public class myComparer : IComparer
        {
            int IComparer.Compare(Object x, Object y)
            {
                return ((new CaseInsensitiveComparer()).Compare(((SortItem)y).Count, ((SortItem)x).Count));
            }
        }

        public class SortItem
        {
            private string itemname;
            private int count;
            public SortItem()
            {
            }
            public string ItemName
            {
                get { return itemname; }
                set { itemname = value; }
            }
            public int Count
            {
                get { return count; }
                set { count = value; }
            }
        }

        public System.Collections.Generic.IList<SortItem> ToArrayBySort(ArrayList slist)
        {
            slist.Sort();
            ArrayList sortList = new ArrayList();
            foreach (object obj in slist)
            {
                SortItem sItem = new SortItem();
                sItem.ItemName = obj.ToString();
                sItem.Count = 1;
                if (sortList.Count == 0) { sortList.Add(sItem); continue; }
                if (obj.ToString() == ((SortItem)sortList[sortList.Count - 1]).ItemName)
                {
                    sItem.Count = ((SortItem)sortList[sortList.Count - 1]).Count + 1;
                    sortList.RemoveAt(sortList.Count - 1);
                }
                sortList.Add(sItem);
            }
            myComparer myCm = new myComparer();
            sortList.Sort(myCm);

            System.Collections.Generic.IList<SortItem> iList = new System.Collections.Generic.List<SortItem>();
            foreach (object obj in sortList)
            {
                iList.Add((SortItem)obj);
                //Response.Write(((SortItem)obj).ItemName + "-" + ((SortItem)obj).Count.ToString() + "<br />");
            }
            return iList;

        }
    </script>

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告