一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

[c#]asp.ent下開發中Tag的開發技巧

網站開發常用關鍵字(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>

AspNet技術[c#]asp.ent下開發中Tag的開發技巧,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲激情黄色 | 亚洲一区二区三区高清网 | 精品欧美一区二区三区四区 | 怡红院美国分院一区二区 | 激情在线观看视频免费的 | 日韩精品一级a毛片 | 久久精品亚洲一级毛片 | 国产精品免费一区二区三区四区 | 国产精品一区二区三区四区 | 欧美xx在线| 国产精品午夜高清在线观看 | 午夜视频免费国产在线 | 四虎影永久在线观看网址 | 全部免费69堂在线视频 | 91精品国产免费入口 | 国产高清视频免费 | 91在线亚洲综合在线 | 97成人精品视频在线播放 | www.亚洲天堂网 | 国产精品久久久久久久成人午夜 | 久久国产精品免费一区二区三区 | 高清国产美女一级a毛片 | 激情综合站 | 日韩欧美在线播放视频 | 国产综合色在线视频区色吧图片 | 国产成人午夜极速观看 | 色婷婷综合激情 | 色优优影院 | 欧美黄色a级片 | 久久精彩 | 亚洲美女视频网 | 无码中文字幕日韩专区 | 亚洲视色 | 日本一区二区三区在线 视频观看免费 | 国产日韩精品一区在线不卡 | 不卡视频一区 | 一区二区三区免费视频观看 | 理论片 我不卡影院 | 久久精视频 | 搞黄网站在线观看 | 国产手机在线 |