MDB 数据库中 按汉字拼音首字母查找记录 如何用 SQL 语句实现(40分)

  • 主题发起人 主题发起人 dngjzx
  • 开始时间 开始时间
D

dngjzx

Unregistered / Unconfirmed
GUEST, unregistred user!
帮朋友写一个通信录在信息查找部分有台下两个功能:
单击某一按钮如:“A” 显示出所有姓的拼音首字母为 A的记录
组合查找如: 输入 YB 显示出姓名中 第一个汉字拼音首字母为 Y 第二个汉字拼音首字母为 B 的所有记录
请问 如何用 SQL 语句实现
注:
// 获取指定汉字的拼音索引字母,如:“汉”的索引字母是“H”
function GetPYIndexChar( hzchar:string):char;
begin
case WORD(hzchar[1]) shl 8 + WORD(hzchar[2]) of
$B0A1..$B0C4 : result := 'A';
$B0C5..$B2C0 : result := 'B';
$B2C1..$B4ED : result := 'C';
$B4EE..$B6E9 : result := 'D';
$B6EA..$B7A1 : result := 'E';
$B7A2..$B8C0 : result := 'F';
$B8C1..$B9FD : result := 'G';
$B9FE..$BBF6 : result := 'H';
$BBF7..$BFA5 : result := 'J';
$BFA6..$C0AB : result := 'K';
$C0AC..$C2E7 : result := 'L';
$C2E8..$C4C2 : result := 'M';
$C4C3..$C5B5 : result := 'N';
$C5B6..$C5BD : result := 'O';
$C5BE..$C6D9 : result := 'P';
$C6DA..$C8BA : result := 'Q';
$C8BB..$C8F5 : result := 'R';
$C8F6..$CBF9 : result := 'S';
$CBFA..$CDD9 : result := 'T';
$CDDA..$CEF3 : result := 'W';
$CEF4..$D188 : result := 'X';
$D1B9..$D4D0 : result := 'Y';
$D4D1..$D7F9 : result := 'Z';
else
result := char(0);
end;
end;
// 获取指定汉字字符串的拼音首字母
function GetPinYin(sHZ: string;mode: integer = 1): string;
var
i: Integer;
PY: string;
s: string;
function GetPYIndexChar(hzchar: string): char;
begin
case WORD(hzchar[1]) shl 8 + WORD(hzchar[2]) of
$B0A1..$B0C4: result := 'a';
$B0C5..$B2C0: result := 'b';
$B2C1..$B4ED: result := 'c';
$B4EE..$B6E9: result := 'd';
$B6EA..$B7A1: result := 'e';
$B7A2..$B8C0: result := 'f';
$B8C1..$B9FD: result := 'g';
$B9FE..$BBF6: result := 'h';
$BBF7..$BFA5: result := 'j';
$BFA6..$C0AB: result := 'k';
$C0AC..$C2E7: result := 'l';
$C2E8..$C4C2: result := 'm';
$C4C3..$C5B5: result := 'n';
$C5B6..$C5BD: result := 'o';
$C5BE..$C6D9: result := 'p';
$C6DA..$C8BA: result := 'q';
$C8BB..$C8F5: result := 'r';
$C8F6..$CBF9: result := 's';
$CBFA..$CDD9: result := 't';
$CDDA..$CEF3: result := 'w';
$CEF4..$D188: result := 'x';
$D1B9..$D4D0: result := 'y';
$D4D1..$D7F9: result := 'z';
else
result := char(32);
end;
end;
begin
s := '';
i := 1;
while i <= Length(sHZ) do
begin
PY := Copy(sHZ, i, 1);
if PY >= Chr(128) then
begin
Inc(i);
PY := PY + Copy(sHZ, i, 1);
s := s + GetPYIndexChar(PY);
end
else
s := s + PY;
Inc(i);
end;
case mode of
1: result := UpperCase(s);
2: result := LowerCase(s);
else
result := s;
end; //case
end;
 
在数据库中添加一个字段记录汉字的首字母(通过上面提供的函数)然后用sql 语句实现
Fieldbyname('name').AsString:=Trim(Edit2.Text);
Fieldbyname('py').AsString:=GetPinYin(edit2.Text);
//SQL语句,key为输入的关键字
adoquery1.Close;
adoquery1.SQL.Clear ;
adoquery1.SQL.Text:='select * from client_data where py like'''+key+'%''';
adoquery1.Open;
 
大哥可不可以不添加字段,这样耗资源
 
后退
顶部