欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

asp.net 根据汉字的拼音首字母搜索数据库(附 LINQ 调用方法)

时间:2021-12-22 10:22:56|栏目:.NET代码|点击:
方法一:先查询出所有记录,然后在逻辑层转化为拼音首字母后查询,显然傻瓜才会这么做。

方法二:在需要搜索的表中添加一个字段用于存放被检索字段内容对应的拼音,在搜索的时候同时去查询这两个字段,这种方法可行,但会增加数据库存放的大小。

方法三:在数据库中建立一个函数,在执行查询语句时通过此函数来转化搜索,函数如下:

复制代码 代码如下:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: xoyozo
-- Create date: 2010-4-17
-- Description: 提供中文首字母
-- =============================================
CREATE FUNCTION fun_getPY
(
@str NVARCHAR(4000)
)
RETURNS NVARCHAR(4000)
AS
BEGIN
DECLARE @word NCHAR(1),@PY NVARCHAR(4000)
SET @PY=''
WHILE len(@str)>0
BEGIN
SET @word=left(@str,1)
SET @PY=@PY+(CASE WHEN unicode(@word) BETWEEN 19968 AND 19968+20901
THEN (SELECT TOP 1 PY FROM (
SELECT 'A' AS PY,N'?' AS word
UNION ALL SELECT 'B',N'簿'
UNION ALL SELECT 'C',N'?e'
UNION ALL SELECT 'D',N'?z'
UNION ALL SELECT 'E',N'??'
UNION ALL SELECT 'F',N'?v'
UNION ALL SELECT 'G',N'?B'
UNION ALL SELECT 'H',N'??'
UNION ALL SELECT 'J',N'?h'
UNION ALL SELECT 'K',N'?i'
UNION ALL SELECT 'L',N'?w'
UNION ALL SELECT 'M',N'??'
UNION ALL SELECT 'N',N'??'
UNION ALL SELECT 'O',N'?a'
UNION ALL SELECT 'P',N'曝'
UNION ALL SELECT 'Q',N'??'
UNION ALL SELECT 'R',N'?U'
UNION ALL SELECT 'S',N'?R'
UNION ALL SELECT 'T',N'?X'
UNION ALL SELECT 'W',N'?F'
UNION ALL SELECT 'X',N'?R'
UNION ALL SELECT 'Y',N'?'
UNION ALL SELECT 'Z',N'??'
) T
WHERE word>=@word COLLATE Chinese_PRC_CS_AS_KS_WS
ORDER BY PY ASC) ELSE @word END)
SET @str=right(@str,len(@str)-1)
END
RETURN @PY
END



使用方法:
复制代码 代码如下:

select * from 表 where fun_getPY(字段) like N'%zgr%'



此方法是最快捷方便的,通过测试在文章表中搜索标题首字母,其耗时大约为不使用此函数搜索的 3 倍,相信部署在小数据量的项目中的成本是非常低的。

LINQ 方式操作
初学 LINQ 的朋友或许对 .dbml 文件不是很熟悉,数据库中的表可以直接拖动到 .dbml 的左侧,而存储过程、函数等可以直接拖到其右侧,然后就可以直接在逻辑使用了,下面是例子:
复制代码 代码如下:

DataClasses1DataContext db = new DataClasses1DataContext();
var q = from d in db.Documents
where d.Title.Contains("zgr") || db.fun_getPY(d.Title).Contains("zgr")
select d;

上一篇:C#规则引擎RulesEngine的具体使用

栏    目:.NET代码

下一篇:C#实现Base64编码与解码及规则

本文标题:asp.net 根据汉字的拼音首字母搜索数据库(附 LINQ 调用方法)

本文地址:http://www.codeinn.net/misctech/187677.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有