ASP.NET从数据库中获取姓名这一字段的记录的每个汉字的拼音首字母

例:数据库中存在姓名这一字段姓名张三李四王五要求:能够根据每条记录中的每个汉字的拼音的首字母进行查询也就是说输入zs(张三),在GridView中能够显示出来这条记录的详... 例:数据库中存在姓名这一字段
姓名
张三
李四
王五
要求:能够根据每条记录中的每个汉字的拼音的首字母进行查询
也就是说输入 zs (张三),在GridView中能够显示出来这条记录的详细信息
不胜感激。
展开
 我来答
leon382
2010-08-18 · TA获得超过1064个赞
知道小有建树答主
回答量:1744
采纳率:0%
帮助的人:975万
展开全部
或许可这样来处理
1:查询出数据集 循环遍列 同时把数据库的姓名字段首字母转成汉语拼音后比对和输入的数据是否相同 相同则将其添入另外一个datatable 最后把datatable给gridview 作为数据源
2:在数据库里加一个冗余字段存姓名的汉字拼音的首字母 最后查询这个字段
把数据绑定到gridview

若有不明 你可以hi我
DP爱问
2010-08-18 · 超过10用户采纳过TA的回答
知道答主
回答量:25
采纳率:0%
帮助的人:0
展开全部
你还是在数据库中把拼音的缩写先写在里面吧,因为不可能在数据库中将汉字对应到拼音。下面的代码是我在网上找的一般处理将汉字转成拼音的缩写的方法,但是这种方法只对一级字库好用,也就是一些常用的汉字。
public string GetPYString(string str)
{
string tempStr = "";

foreach (char c in str)
{
if ((int)c >= 33 && (int)c <= 126)
{//字母和符号原样保留
tempStr += c.ToString();
}
else
{//累加拼音声母
tempStr += GetPYChar(c.ToString());
//this.textBox1.Text = (((int)c).ToString());
}
}
return tempStr;
}
public string GetPYChar(string c)
{
byte[] array = new byte[2];
array = System.Text.Encoding.Default.GetBytes(c);
int i = (short)(array[0] - '\0') * 256 + ((short)(array[1] - '\0'));
if ( i < 0xB0A1) return "*";
if ( i < 0xB0C5) return "a";
if ( i < 0xB2C1) return "b";
if ( i < 0xB4EE) return "c";
if ( i < 0xB6EA) return "d";
if ( i < 0xB7A2) return "e";
if ( i < 0xB8C1) return "f";
if ( i < 0xB9FE) return "g";
if ( i < 0xBBF7) return "h";
if ( i < 0xBFA6) return "g";
if ( i < 0xC0AC) return "k";
if ( i < 0xC2E8) return "l";
if ( i < 0xC4C3) return "m";
if ( i < 0xC5B6) return "n";
if ( i < 0xC5BE) return "o";
if ( i < 0xC6DA) return "p";
if ( i < 0xC8BB) return "q";
if ( i < 0xC8F6) return "r";
if ( i < 0xCBFA) return "s";
if ( i < 0xCDDA) return "t";
if ( i < 0xCEF4) return "w";
if ( i < 0xD1B9) return "x";
if ( i < 0xD4D1) return "y";
if ( i < 0xD7FA) return "z";
return "*";
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式