一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - 用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

2020-06-21 15:29zz_cl JAVA教程

這篇文章主要為大家詳細(xì)介紹了仿360首頁支持拼音輸入全模糊搜索和自動換膚的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

360首頁搜索效果如下

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

1、完成編寫的schoolnet校園網(wǎng)主要目錄結(jié)構(gòu)如下

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

主要實現(xiàn)支持中文、拼音首字母、拼音全字母的智能搜索和換膚

頁面效果如下

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

用java等語言仿360首頁拼音輸入全模糊搜索和自動換膚

主要核心代碼如下

1、head.jsp

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
<%@page import="java.io.File"%>
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<title>校園網(wǎng)首頁面</title>
<link rel="stylesheet" href="/schoolnet/css/index.css" type="text/css" />
<script type="text/javascript" src="/schoolnet/js/ddsmoothmenu.js"></script>
<script src="/schoolnet/js/jquery.js"></script>
<script src="/schoolnet/js/jquery-ui.js"></script>
<script type="text/javascript" src="/schoolnet/js/publicJs.js"></script>
<script type="text/javascript" src="/schoolnet/myAJAX/ajax_uni.js"></script>
<script type="text/javascript" src="/schoolnet/js/style.js"></script>
<c:if test="${loginuser.skin.id!=null }">
 <script type="text/javascript">
  $(document).ready(
 
    function setskin() {
     var photo = '${loginuser.skin.photo}';
     $("body").css(
       "background",
       "#f6f6f6 url(/schoolnet/images/pf/" + photo
         + ") top repeat");
    });
 </script>
 
 
</c:if>
</head>
<body>
 <div class="topsearch">
  <div class="topsearchtype" id="searchtype">
   <a class="current" href="javascript:void(0)"
    onclick="setsearchtype(this),setsearch()" name="searchdatas"
    id="books.png">資料</a> <a href="javascript:void(0)"
    onclick="setsearchtype(this),setsearch()" name="searchsongs"
    id="t01d566d0c28b32ddad.png">音樂</a> <a href="javascript:void(0)"
    onclick="setsearchtype(this),setsearch()" name="searchnews"
    id="newspaper.png">新聞</a> <a href="javascript:void(0)"
    onclick="setsearchtype(this),setsearch()" name="searchxiaoshuos"
    id="library.png">小說</a> <a href="javascript:void(0)"
    onclick="setsearchtype(this),setsearch()" name="searcharticles"
    id="blog.gif">日志</a>
  </div>
  <form id="search-form"
   action="/schoolnet/other.do?flag=searchdatas&searchpageNow=1"
   method="post" name="searchdatas" target="blank"
   onsubmit="return checksearch()">
   <img src="/schoolnet/images/front/books.png" id="searchimg"
    width="32px" height="32px" style="margin-bottom:-10px" /><input
    type="text" class="topsearchtext" name="search" id="topsearchtext"
    onkeyup="setsearch()" onfocus="newsearch()" "/> <input
    id="inputsearchtype" type="submit" class="topsearchbutton"
    value="搜索資料" />
  </form>
  <ul id="setsearch" class="setsearch">
  </ul>
 </div>
 <div id="MainMenu" class="ddsmoothmenu">
  <ul>
   <li><a href="/schoolnet/login.do?flag=goHomeUI" title=""
    id="*menu_selected"><span>校園網(wǎng)</span>
   </a>
   </li>
   <li><a href="/schoolnet/login.do?flag=goHomeUI" title=""><span>個人中心</span>
   </a></li>
   <li><a href="/schoolnet/profile.do?flag=goHomePageUI" title=""><span>我的主頁</span>
   </a></li>
   <li><a href="javascript:void(0)" title=""><span>應(yīng)用</span>
   </a>
   <ul class="menulevel">
     <li><a href="/schoolnet/shou.do?flag=ShuoShuo&pageNow=1"
      title="">說說</a>
     </li>
     <li><a
      href="/schoolnet/album.do?flag=myAlbumUI&pageNow=1&userid=${loginuser.id }"
      title="">相冊</a>
     </li>
     <li><a href="/schoolnet/friend.do?flag=myfriendUI&pageNow=1"
      title="">好友</a>
     </li>
     <li><a
      href="/schoolnet/article.do?flag=articleUI&pageNow=1&userid=${loginuser.id }"
      title="">日志</a>
     </li>
     <li><a href="/schoolnet/music.do?flag=goMusicHome&pageNow=1"
      title="">音樂</a>
     </li>
     <li><a
      href="/schoolnet/news.do?flag=gonewsUI&typeid=1&pageNow=1"
      title="">新聞</a>
     </li>
     <li><a
      href="/schoolnet/datas.do?flag=godatasUI&pageNow=1&action=all"
      title="">資料</a>
     </li>
     <li><a
      href="/schoolnet/xiaoshuo.do?flag=goxiaoshuoUI&pageNow=1&id=all"
      title="">小說</a>
     </li>
     <li><a
      href="/schoolnet/skin.do?flag=goskinUI&pageNow=1&id=all" title="">裝扮</a>
     </li>
     <li><a href="/schoolnet/share .do?flag=goShareUI&pageNow=1"
      title="">新鮮事</a>
     </li>
    </ul>
   </li>
   <li><a href="javascript:void(0)" title=""><span>關(guān)于</span>
   </a>
   <ul class="menulevel">
     <li><a href="/schoolnet/other.do?flag=goAboutUI#1" title="">關(guān)于我們</a>
     </li>
     <li><a href="/schoolnet/other.do?flag=goAboutUI#2" title="">網(wǎng)站地圖</a>
     </li>
     <li><a href="/schoolnet/other.do?flag=goAboutUI#3" title="">版權(quán)說明</a>
     </li>
     <li><a href="/schoolnet/other.do?flag=goAboutUI#4" title="">友情鏈接</a>
     </li>
    </ul>
   </li>
   <li><a href="javascript:void(0)" title=""><span>設(shè)置</span>
   </a>
   <ul class="menulevel">
     <li><a href="/schoolnet/register.do?flag=updUI">修改個人信息</a>
     </li>
     <li><a href="/schoolnet/login.do?flag=logout">退出</a>
     </li>
    </ul>
   </li>
  </ul>
  <c:if test="${loginuser!=null }">
   <div id="page-wrap">
    <ul class="dropdown">
     <li id="menu_selected"><a id="menu_selected"
      href="/schoolnet/login.do?flag=goHomeUI">  <img
       src="/schoolnet/images/head/${loginuser.photo}" width="120px"
       height="45px" style=" margin-top:-18px;margin-left:-10px" />
     </a>
      <ul class="sub_menu">
       <li><a href="/schoolnet/register.do?flag=updUI">修改個人信息</a>
       </li>
       <li><a href="/schoolnet/login.do?flag=logout">退出</a>
       </li>
      </ul></li>
    </ul>
   </div>
  </c:if>
 </div>
</body>
</html>

2、主要js函數(shù)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//用于設(shè)置切換搜索類型,觸發(fā)input控件焦點時顯示對應(yīng)的熱門(前五個)內(nèi)容(資料、音樂、新聞、小說、日志)
function setsearchtype(o){
 $("#searchtype a").removeClass("current");
 $(o).addClass("current");
 var inputsearchtype=$(o).text();
 $("#inputsearchtype").val("搜索"+inputsearchtype);
 document.getElementById("search-form").action="/schoolnet/other.do?flag="+o.name+"&searchpageNow=1";
 document.getElementById("search-form").name=o.name;
 document.getElementById("searchimg").src="/schoolnet/images/front/"+o.id;
 $("#topsearchtext").show();
 $("#searchfriendss").hide();
 if(o.name=="searchfriends")
  {
   $("#topsearchtext").hide();
   $("#searchfriendss").show();
  }
}
//用于設(shè)置顯示智能提示的內(nèi)容(模糊搜索時匹配的前十個)
function setsearch()
{
 var v=document.getElementById("topsearchtext").value;
 var type=document.getElementById("search-form").name;
 if(v.length==0)
  {
  $("#setsearch").html("");
  }
 if(v.length>0)
 {
  $.ajax({    
   cache: true,    
   type: "POST",    
   url : "/schoolnet/ChangeInfo",   
   data: {"action":"setsearch","search":v,"searchtype":type},
   async: false,
   dataType: "html",
   success: function(data) {
    $("#setsearch").html("");
    $("#setsearch").append(data);
   
   });
 };
}

主要java文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
if("searchsongs".equals(searchtype))
<span style="white-space:pre">   </span>{
<span style="white-space:pre">    </span>String nameHEAD[]=ChinesePinYinTool.getHeadByString(search);
<span style="white-space:pre">    </span>String nameHeadString="";
<span style="white-space:pre">    </span>for (int i = 0; i < nameHEAD.length; i++) {
<span style="white-space:pre">     </span>nameHeadString+=nameHEAD[i];
<span style="white-space:pre">    </span>}
<span style="white-space:pre">    </span>String nameALL[]=ChinesePinYinTool.stringToPinyin(search);
<span style="white-space:pre">    </span>String nameAllString="";
<span style="white-space:pre">    </span>for (int i = 0; i < nameALL.length; i++) {
<span style="white-space:pre">     </span>nameAllString+=nameALL[i];
<span style="white-space:pre">    </span>}
<span style="white-space:pre">    </span>List<Song> songs=universityService.executeQueryByPage("from Song where to_pinyin(name) like '%"+ nameAllString +"%' or pinyin(name) like '%"+ nameHeadString +"%'", null, 1, 10);
<span style="white-space:pre">    </span>for(int i=0;i<songs.size();i++)
<span style="white-space:pre">    </span>{
<span style="white-space:pre">     </span>con +="<li><a target='blank' href='/schoolnet/music.do?flag=goPatentDisplay&pid="+songs.get(i).getPatent().getId()+"'>"+songs.get(i).getName()+"</a></li>";
<span style="white-space:pre">    </span>}
<span style="white-space:pre">    </span>if (songs.size()!=0) {
<span style="white-space:pre">     </span>con +="<li><a href='javascript:void(0)' onclick='hideli()' style='display:inline;float:right;margin-right:8px;'>關(guān)閉</a></li>";
<span style="white-space:pre">    </span>}
<span style="white-space:pre">    </span>else {
<span style="white-space:pre">     </span>con +="<li><a href='javascript:void(0)' onclick='hideli()' style='display:inline;'>無任意匹配結(jié)果</a></li>";
<span style="white-space:pre">    </span>}
<span style="white-space:pre">    </span>out.write(con);
<span style="white-space:pre">    </span>out.close();
<span style="white-space:pre">   </span>}
else if("setpifu".equals(action))
<span style="white-space:pre">  </span>{
<span style="white-space:pre">   </span>String skinid=request.getParameter("skinid");
<span style="white-space:pre">   </span>Skin skin=(Skin) universityService.findById(Skin.class, Integer.valueOf(skinid));
<span style="white-space:pre">   </span>Users user=(Users) request.getSession().getAttribute("loginuser");
<span style="white-space:pre">   </span>user.setSkin(skin);
<span style="white-space:pre">   </span>universityService.update(user);
<span style="white-space:pre">  </span>}

做拼音轉(zhuǎn)換時需導(dǎo)入pinyin4j.jar包
ChinesePinYinTool拼音轉(zhuǎn)換工具類
package schoolnet.utils;  

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
import net.sourceforge.pinyin4j.PinyinHelper;
import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType;
import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat;
import net.sourceforge.pinyin4j.format.HanyuPinyinToneType;
import net.sourceforge.pinyin4j.format.exception.BadHanyuPinyinOutputFormatCombination;
 
/**
 *
 * 漢語拼音工具
 *
 *
 *
 */
public class ChinesePinYinTool {
 public static void main(String[] args) {
  String string[]=stringToPinyin("這個");
  for (int i = 0; i < string.length; i++) {
   System.out.println(string[i]);
  }
 }
 /**
  *
  * 將字符串轉(zhuǎn)換成拼音數(shù)
  *
  *
  * @param src
  * @return
  */
 public static String[] stringToPinyin(String src) {
  return stringToPinyin(src, false, null);
 }
 
 /**
  * 將字符串轉(zhuǎn)換成拼音數(shù)
  *
  *
  * @param src
  * @return
  */
 public static String[] stringToPinyin(String src, String separator) {
  return stringToPinyin(src, true, separator);
 }
 
 /**
  * 將字符串轉(zhuǎn)換成拼音數(shù)
  *
  *
  * @param src
  * @param isPolyphone
  *   是否查出多音字的拼音
 
  *
  * @param separator
  *   多音字拼音之間的分隔
  *
  * @return
  */
 public static String[] stringToPinyin(String src, boolean isPolyphone,
   String separator) {
  // 判斷字符串是否為
 
  if ("".equals(src) || null == src) {
   return null;
  }
  char[] srcChar = src.toCharArray();
  int srcCount = srcChar.length;
  String[] srcStr = new String[srcCount];
 
  for (int i = 0; i < srcCount; i++) {
   srcStr[i] = charToPinyin(srcChar[i], isPolyphone, separator);
  }
  return srcStr;
 }
 
 /**
  * 將單個字符轉(zhuǎn)換成拼音
  *
  * @param src
  * @return
  */
 public static String charToPinyin(char src, boolean isPolyphone,
   String separator) {
  // 創(chuàng)建漢語拼音處理
  HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();
  // 輸出設(shè)置,大小寫,音標(biāo)方
  defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);
  defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
  StringBuffer tempPinying = new StringBuffer();
  // 如果是中
  if (src > 128) {
   try {
    // 轉(zhuǎn)換得出結(jié)果
    String[] strs = PinyinHelper.toHanyuPinyinStringArray(src,
      defaultFormat);
    // 是否查出多音字,默認(rèn)是查出多音字的第字符
 
    if (isPolyphone && null != separator) {
     for (int i = 0; i < strs.length; i++) {
      tempPinying.append(strs[i]);
      if (strs.length != (i + 1)) {
       // 多音字之間用特殊符號間隔起來
       tempPinying.append(separator);
      }
     }
    } else {
     tempPinying.append(strs[0]);
    }
 
   } catch (BadHanyuPinyinOutputFormatCombination e) {
    e.printStackTrace();
   }
  } else {
   tempPinying.append(src);
  }
 
  return tempPinying.toString();
 
 }
 
 public static String hanziToPinyin(String hanzi) {
  return hanziToPinyin(hanzi, "");
 }
 
 /**
  * 將漢字轉(zhuǎn)換成拼音
  *
  * @param hanzi
  * @param separator
  * @return
  */
 @SuppressWarnings("deprecation")
 public static String hanziToPinyin(String hanzi, String separator) {
  // 創(chuàng)建漢語拼音處理
  HanyuPinyinOutputFormat defaultFormat = new HanyuPinyinOutputFormat();
  // 輸出設(shè)置,大小寫,音標(biāo)方
  defaultFormat.setCaseType(HanyuPinyinCaseType.LOWERCASE);
  defaultFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
  String pinyingStr = "";
  try {
   pinyingStr = PinyinHelper.toHanyuPinyinString(hanzi, defaultFormat,
     separator);
  } catch (BadHanyuPinyinOutputFormatCombination e) {
   e.printStackTrace();
  }
  return pinyingStr;
 }
 
 /**
  * 將字符串?dāng)?shù)組轉(zhuǎn)換成字符串
  *
  * @param str
  * @param separator
  *   各個字符串之間的分隔
  *
  * @return
  */
 public static String stringArrayToString(String[] str, String separator) {
  StringBuffer sb = new StringBuffer();
  for (int i = 0; i < str.length; i++) {
   sb.append(str[i]);
   if (str.length != (i + 1)) {
    sb.append(separator);
   }
  }
  return sb.toString();
 }
 
 /**
  * 的將各個字符數(shù)組之間連接起來
 
  *
  *
  * @param str
  * @return
  */
 public static String stringArrayToString(String[] str) {
  return stringArrayToString(str, "");
 }
 
 /**
  * 將字符數(shù)組轉(zhuǎn)換成字符
  *
  *
  * @param str
  * @param separator
  *   各個字符串之間的分隔
  *
  * @return
  */
 public static String charArrayToString(char[] ch, String separator) {
  StringBuffer sb = new StringBuffer();
  for (int i = 0; i < ch.length; i++) {
   sb.append(ch[i]);
   if (ch.length != (i + 1)) {
    sb.append(separator);
   }
  }
  return sb.toString();
 }
 
 /**
  * 將字符數(shù)組轉(zhuǎn)換成字符
  *
  *
  * @param str
  * @return
  */
 public static String charArrayToString(char[] ch) {
  return charArrayToString(ch, " ");
 }
 
 /**
  * 取漢字的首字
  *
  *
  * @param src
  * @param isCapital
  *   是否是大
  *
  * @return
  */
 public static char[] getHeadByChar(char src, boolean isCapital) {
  // 如果不是漢字直接返回
  if (src <= 128) {
   return new char[] { src };
  }
  // 獲取的拼
  String[] pinyingStr = PinyinHelper.toHanyuPinyinStringArray(src);
  // 創(chuàng)建返回對象
  int polyphoneSize = pinyingStr.length;
  char[] headChars = new char[polyphoneSize];
  int i = 0;
  // 截取首字
 
  for (String s : pinyingStr) {
   char headChar = s.charAt(0);
   // 首字母是否大寫,默認(rèn)是小
 
   if (isCapital) {
    headChars[i] = Character.toUpperCase(headChar);
   } else {
    headChars[i] = headChar;
   }
   i++;
  }
 
  return headChars;
 }
 
 /**
  * 取漢字的首字默認(rèn)是大
  *
  * @param src
  * @return
  */
 public static char[] getHeadByChar(char src) {
  return getHeadByChar(src, true);
 }
 
 /**
  * 查找字符串首字母
  *
  * @param src
  * @return
  */
 public static String[] getHeadByString(String src) {
  return getHeadByString(src, true);
 }
 
 /**
  * 查找字符串首字母
  *
  * @param src
  * @param isCapital
  *   是否大寫
  * @return
  */
 public static String[] getHeadByString(String src, boolean isCapital) {
  return getHeadByString(src, isCapital, null);
 }
 
 /**
  * 查找字符串首字母
  *
  * @param src
  * @param isCapital
  *   是否大寫
  * @param separator
  *   分隔
  *
  * @return
  */
 public static String[] getHeadByString(String src, boolean isCapital,
   String separator) {
  char[] chars = src.toCharArray();
  String[] headString = new String[chars.length];
  int i = 0;
  for (char ch : chars) {
 
   char[] chs = getHeadByChar(ch, isCapital);
   StringBuffer sb = new StringBuffer();
   if (null != separator) {
    int j = 1;
 
    for (char ch1 : chs) {
     sb.append(ch1);
     if (j != chs.length) {
      sb.append(separator);
     }
     j++;
    }
   } else {
    sb.append(chs[0]);
   }
   headString[i] = sb.toString();
   i++;
  }
  return headString;
 }
}

數(shù)據(jù)庫建立相關(guān)函數(shù)
fristPinyin : 此函數(shù)是將一個中文字符串的第一個漢字轉(zhuǎn)成拼音首字母 (例如:"好的"->h)
pinyin :此函數(shù)是將一個中文字符串對應(yīng)拼音首字母的每個相連 (例如:"好的"->hd)
to_pinyin :此函數(shù)是將一個中文字符串對應(yīng)拼音全字母的每個相連 (例如:"好的"->haode)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
CREATE FUNCTION `fristPinyin`(P_NAME VARCHAR(255)) RETURNS varchar(255) CHARSET utf8
BEGIN
 DECLARE V_RETURN VARCHAR(255);
 SET V_RETURN = ELT(INTERVAL(CONV(HEX(left(CONVERT(P_NAME USING gbk),1)),16,10),
  0xB0A1,0xB0C5,0xB2C1,0xB4EE,0xB6EA,0xB7A2,0xB8C1,0xB9FE,0xBBF7,
  0xBFA6,0xC0AC,0xC2E8,0xC4C3,0xC5B6,0xC5BE,0xC6DA,0xC8BB,
  0xC8F6,0xCBFA,0xCDDA,0xCEF4,0xD1B9,0xD4D1), 
 'A','B','C','D','E','F','G','H','J','K','L','M','N','O','P','Q','R','S','T','W','X','Y','Z');
 RETURN V_RETURN;
END
CREATE FUNCTION `pinyin`(P_NAME VARCHAR(255)) RETURNS varchar(255) CHARSET utf8
BEGIN
 DECLARE V_COMPARE VARCHAR(255);
 DECLARE V_RETURN VARCHAR(255);
 DECLARE I INT;
 
 SET I = 1;
 SET V_RETURN = '';
 while I < LENGTH(P_NAME) do
  SET V_COMPARE = SUBSTR(P_NAME, I, 1);
  IF (V_COMPARE != '') THEN
   #SET V_RETURN = CONCAT(V_RETURN, ',', V_COMPARE);
   SET V_RETURN = CONCAT(V_RETURN, fristPinyin(V_COMPARE));
   #SET V_RETURN = fristPinyin(V_COMPARE);
  END IF;
  SET I = I + 1;
 end while;
 
 IF (ISNULL(V_RETURN) or V_RETURN = '') THEN
  SET V_RETURN = P_NAME;
 END IF;
 
 RETURN V_RETURN;
END
CREATE FUNCTION to_pinyin(NAME VARCHAR(255) CHARSET gbk)
RETURNS VARCHAR(255) CHARSET gbk
BEGIN
 DECLARE mycode INT;
 DECLARE tmp_lcode VARCHAR(2) CHARSET gbk;
 DECLARE lcode INT;
 DECLARE tmp_rcode VARCHAR(2) CHARSET gbk;
 DECLARE rcode INT;
 DECLARE mypy VARCHAR(255) CHARSET gbk DEFAULT '';
 DECLARE lp INT;
 SET mycode = 0;
 SET lp = 1;
 SET NAME = HEX(NAME);
 WHILE lp < LENGTH(NAME) DO
  SET tmp_lcode = SUBSTRING(NAME, lp, 2);
  SET lcode = CAST(ASCII(UNHEX(tmp_lcode)) AS UNSIGNED); 
  SET tmp_rcode = SUBSTRING(NAME, lp + 2, 2);
  SET rcode = CAST(ASCII(UNHEX(tmp_rcode)) AS UNSIGNED); 
  IF lcode > 128 THEN
   SET mycode =65536 - lcode * 256 - rcode ;
   SELECT CONCAT(mypy,pin_yin_) INTO mypy FROM t_base_pinyin WHERE CODE_ >= ABS(mycode) ORDER BY CODE_ ASC LIMIT 1;
   SET lp = lp + 4;
  ELSE
   SET mypy = CONCAT(mypy,CHAR(CAST(ASCII(UNHEX(SUBSTRING(NAME, lp, 2))) AS UNSIGNED)));
   SET lp = lp + 2;
  END IF;
 END WHILE;
 RETURN LOWER(mypy);
END;

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美在线视频一区二区 | 日本无遮挡吸乳视频看看 | 亚洲欧美日韩成人 | 久久国产视频网站 | 成成人看片在线 | 日韩欧美在线看 | 性xxxxⅹhd成人| 无遮免费网站在线入口 | 欧美高清videosex极品 | 9久热这里只有精品免费 | 亚洲成熟人网站 | xxxx野外性xxxx| 国产免费丝袜调教视频 | 91热爆| www.com在线观看 | 亚洲国产天堂综合一区 | 国产精品va在线观看不 | 狠狠燥 | 99久久一区二区精品 | 亚洲精品久久啪啪网站成年 | 国产免费美女视频 | 亚欧美色 | sedog在线长片 | 成人在线视频观看 | 精品国产乱码久久久久久免费流畅 | 男男gaygays国内 | 亚洲精品tv久久久久久久久久 | 亚洲天堂在线视频观看 | 波多野结衣被绝伦强在线观看 | 超级碰碰青草免费视频92 | 精品无人区麻豆乱码1区2 | 男人j进女屁股视频在线观看 | 久久理论片迅播影院一级 | 99资源站 | 热99精品 | 波多野结衣家庭教师 | 手机看片日韩1024你懂的首页 | 毛片免费观看 | 国产专区亚洲欧美另类在线 | 日韩欧美一区二区三区免费观看 | 亚洲精品卡一卡2卡3卡4卡 |