网站开发常用关键字(tag),一般需要获得最多的被采用的Tag,也就是流行词。
通常思路是将关键字tag保存到单独表中,然后在其他表中根据一组id进行对多个关键字进行标识。因为一个文章可以选择多个tag,查询的时候颇为麻烦。
所以我在开发中利用了这样的方法,当然不见得多高明:),分享下经验。
将tag直接保存在文章的表中,如Tag字段,tag为“c#”和“.net”,则Tag字段值为“c#/.net”就是依/符号分割tag,这样数据库中保存的是字符串了。单文章显示的时候可以直接分割成数组显示,减少表的关联,提高了效率。
当需要显示最近流行词的时候。
查询所有的tag
selecttagfrom表
利用DataReader把输出结果相加起来。然后根据分隔符转化为字符串,剩下的就是对字符串进行排序,根据tag重多少进行。并返回重复的数量,见代码。为方便查看,我都写在了一个aspx页面中了。
复制代码 代码如下:
<%@PageLanguage="C#"%>
<%@ImportNamespace="System.Data"%>
<%@ImportNamespace="XXXX.BLL"%>
<%@ImportNamespace="XXXX.Model"%>
<%@ImportNamespace="XXXX.DBUtility"%>
<scriptrunat="server">
protectedstringstext;
protectedvoidPage_Load(objectsender,EventArgse)
{
StringBuildersb=newStringBuilder();
using(System.Data.SqlClient.SqlDataReaderrd=XXXX.DBUtility.SqlHelper.ExecuteReader(SqlHelper.ConnectionString,System.Data.CommandType.Text,"SelectKinds+'/'FROMXXX",null))
{
while(rd.Read())
{
sb.Append(rd.GetString(0));
}
}
stext=sb.ToString();
ToArrayBySort(ToArray(stext,'/'));
}
///<summary>
///将字符串根据分隔符转化为数组
///</summary>
///<paramname="sourcestring">要转化的字符串</param>
///<paramname="compart">分隔符</param>
///<returns></returns>
publicArrayListToArray(stringsourcestring,charsplit)
{
CharEnumeratorce=sourcestring.GetEnumerator();
StringBuildersb=newStringBuilder();
ArrayListslist=newArrayList();
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);
}
}
returnslist;
}
publicclassmyComparer:IComparer
{
intIComparer.Compare(Objectx,Objecty)
{
return((newCaseInsensitiveComparer()).Compare(((SortItem)y).Count,((SortItem)x).Count));
}
}
publicclassSortItem
{
privatestringitemname;
privateintcount;
publicSortItem()
{
}
publicstringItemName
{
get{returnitemname;}
set{itemname=value;}
}
publicintCount
{
get{returncount;}
set{count=value;}
}
}
publicSystem.Collections.Generic.IList<SortItem>ToArrayBySort(ArrayListslist)
{
slist.Sort();
ArrayListsortList=newArrayList();
foreach(objectobjinslist)
{
SortItemsItem=newSortItem();
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);
}
myComparermyCm=newmyComparer();
sortList.Sort(myCm);
System.Collections.Generic.IList<SortItem>iList=newSystem.Collections.Generic.List<SortItem>();
foreach(objectobjinsortList)
{
iList.Add((SortItem)obj);
//Response.Write(((SortItem)obj).ItemName+"-"+((SortItem)obj).Count.ToString()+"<br/>");
}
returniList;
}
</script>