Name:名称
Code:编码
AliasName:别名
MnemonicCode:助记码
PinyinCode:拼音码
需求:首先一张表有五个字段内容需要搜索,无论搜索哪个字段,匹配度要按顺序返回,实现最好的检索效果。
比如以下字段需要检索:
Name:名称
Code:编码
AliasName:别名
MnemonicCode:助记码
PinyinCode:拼音码
1、为了达到更好的搜索效果,对搜索可能性进行排序,比如用户最常用的就是用Name进行搜索,其次是Code,依次排序
2、如果关键字在内容中存在,并且出现在内容中的位置越靠前,权值越高。
你好啊 我是谁,你好啊
比如以上数据中,搜索“啊”,第一条数据中“啊”出现的位置是第三个字符,就比第二条数据匹配度高。
3、数据内容越短,权值越高。
高血压 高血压I型
比如以上数据中,搜索“高血压”,最匹配的明显是第一条数据。
4、现在我们将关键字出现的位置、内容长度进行排序,基本上能实现效果。
但是有个很大的问题:这个字段中,检索不到关键字,其他字段包含关键字,检索不到的字段长度会影响排序位置,直接让检索结果不准确。
我们还需要加一条规则,如果检索不到关键字,这个字段的内容长度要为0,不能影响排序。
综上规则,我们写了一个sql
SELECT Name,Code, AliasName, MnemonicCode, PinyinCode FROM icd_diagnoses WHERE SearchCode LIKE '%高血压%' ORDER BY LOCATE('高血压', Name),if(LOCATE('高血压', Name)>=0,CHAR_LENGTH(Name),0), LOCATE('高血压', Code),if(LOCATE('高血压', Code)>=0, CHAR_LENGTH(Code),0), LOCATE('高血压', PinyinCode),if(LOCATE('高血压', PinyinCode)>=0, CHAR_LENGTH(PinyinCode),0), LOCATE('高血压', AliasName),if(LOCATE('高血压', AliasName)>=0, CHAR_LENGTH(AliasName),0), LOCATE('高血压', MnemonicCode),if(LOCATE('高血压', MnemonicCode)>=0, CHAR_LENGTH(MnemonicCode),0);
这个sql中,每个字段,都将关键字匹配位置、内容长度参与排序,位置为0时,长度也为0
转换为EF的写法,如下:
.Where(e => e.SearchCode.Contains(searchCode)) .OrderBy(x => x.Name.IndexOf(searchCode)) .ThenBy(x => x.Name.IndexOf(searchCode) >= 0 ? x.Name.Length : 0) .ThenBy(x => x.Code.IndexOf(searchCode)) .ThenBy(x => x.Code.IndexOf(searchCode) >= 0 ? x.Code.Length : 0) .ThenBy(x => x.PinyinCode.IndexOf(searchCode)) .ThenBy(x => x.PinyinCode.IndexOf(searchCode) >= 0 ? x.PinyinCode.Length : 0) .ThenBy(x => x.MnemonicCode.IndexOf(searchCode)) .ThenBy(x => x.MnemonicCode.IndexOf(searchCode) >= 0 ? x.MnemonicCode.Length : 0) .ThenBy(x => x.AliasName.IndexOf(searchCode)) .ThenBy(x => x.AliasName.IndexOf(searchCode) >= 0 ? x.AliasName.Length : 0) ;
以上就是全部内容,你如果有更好的方案,可以发给我。
CarsonIT 微信扫码关注公众号 策略、创意、技术
.NET MYSQL ELECTRON 算法 LINUX C# HTML EF CODEFIRST JAVASCRIPT WEBAPI 二维码 .NET6 ORM ELK ELASTICSEARCH 日志归集 工具 SQLSERVER LOGSTASH .NET5 JENKINS 持续集成 自动化部署 CENTOS EFCORE MONGODB HTTPS CANVAS KIBANA
.NET Core 使用本地自签证书实现HTTPS协议
现在要想让你测试的站点支持HTTPS,VS在创建项目的时候,可以直接勾选HTTPS选项,用自带证书,可以实现SSL加密。但是今天解决的问题,如果我项目创建的时候没勾选,我之前不支持HTTPS,现在我要让他支持该如何处理?
可怕的不是死亡,而是你从未真正活过
大部分人恐惧的不是死亡,而是走到生命的尽头时,蓦然回首才发现,你从未真正活过。根据某家医院的研究统计,他们访问了一百名临终的老人,让他们回想,自己一生中最大的遗憾是什么?几乎所有人回答的都不是他们做过的事,而是遗憾他们没做过的事。没冒过的险、没追过的梦。现在我问你:你的人生遗言会是什么?你是否也会回答:“如果我当初...”。醒醒吧!你的人生目标是什么?人生不只是工作,然后等待周末,缴纳房租而已。
.NetCore WebAPI使用Apollo配置中心
Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性,适用于微服务配置管理场景。服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。Java客户端不依赖任何框架,能够运行于所有Java运行时环境,同时对Spring/Spring Boot环境也有较好的支持。
MemCached与Redis的区别
MemCached与Redis都是缓存组件,但是他们俩还是有很多差别,那么我们什么时候选择MemCached?什么时候选择Redis?希望这篇文章可以帮你了解一下
EntityFrameworkCore数据加密存储解决方案
我们平时项目中,有很多数据其实是需要加密存储的,但是我们基本上都只是将密码进行加密存储,如果我们的用户银行卡信息,身份证信息,这些要进行明文显示,但是如果数据泄露,也能保护用户数据的就更好了,今天给大家介绍的就是这样的一个解决方案。
疫情数据关注工具-支持全平台版本(12月15停止更新,一个时代的结束)
疫情形式严峻,我十分关心每天的疫情动态,但是我发现无论是百度的疫情动态,还是腾讯的动态,数据都不完整,而且腾讯的风险地区更新不及时,导致经常看到错误数据。
New MacBook 2016
它比以往速度更快、性能更强大,身形却更纤薄、更轻巧。它为你展现的,是迄今最明亮、最多彩的 Mac 笔记本显示屏。它更带来了开创性的 Multi-Touch Bar:一个内置于键盘的玻璃面多点触控条,让你能在需要时快速取用各种工具。新一代 MacBook Pro 是对我们突破性理念的一场出色演绎,而它,也正期待着演绎你的奇思妙想。
疫情数据关注工具-支持全平台版本(12月15停止更新,一个时代的结束)
疫情形式严峻,我十分关心每天的疫情动态,但是我发现无论是百度的疫情动态,还是腾讯的动态,数据都不完整,而且腾讯的风险地区更新不及时,导致经常看到错误数据。
.NET WebApi配置Swagger详细教程
Swagger可以根据xml文件生成api接口文档,前后端节约沟通时间,减少对接成本,是一个非常好的解决方案;本文主要记录一下,Vs2019从0开始,搭建一个WebApi最终利用Swagger看到相关接口,并解决Swagger汉化的问题,解决Swagger在.net Webapi中控制器名称标注问题。
《灵笼》白月魁 壁纸
国漫《灵笼》特别篇播出,作为第一季的大结局剧情,灵笼在最后一话的特别篇中终于把地面神秘人物白月魁的身份信息给揭露了出来,原来之前马克队长猜得没有错,当时在下到地面采集物资的时候,看到的女子其实就是白月魁小队,她们是生活在地面的人类,但是从本质而言,似乎已经和人类有所区别。
Hangfire任务调度从入门到实践
Hangfire是一个任务调度的组件,自带面板,可以操作正在运作的任务,可以看到执行情况,而且使用起来简单,Hangfire不受特定.NET应用程序类型的限制,只要是.NET Framework 4.5以上,Newtonsoft.Json library ≥ 5.0.1,有一个mysql或者mssql数据库即可。而且最新的支持.NET Core,这篇文章主要记录一下如何在.NET Core 3.1中用mysql来帮助Hangfire实现持久化。
EFcore+MySql 数据迁移的时候,怎么给表结构加注释?
Microsoft.EntityFrameworkCore是一个非常不错的设计,当一套系统里面出现太多的SQL,其实已经不合理了,所以EF让开发者不再接触SQL,而是直接以对象形式操作数据库,EF来负责Sql代码生成和执行,通常在开发中,有根据数据表结构来生成实体的,也有根据实体生成数据库的,就是所谓的DbFirst和CodeFirst,这篇文章主要说一下CodeFirst的应用,用的是MySql数据库。
Resharper 2021.3.2-VS2022可用的扩展插件
ReSharper是一个JetBrains公司出品的著名的代码生成工具。其能帮助Microsoft Visual Studio成为一个更佳的IDE,它包括一系列丰富的能大大增加C#和Visual Basic .net开发者生产力的特征。使用ReSharper,你可以进行深度代码分析,智能代码协助,实时错误代码高亮显示,解决方案范围内代码分析,快速代码更正,一步完成代码格式化和清理,业界领先的自动代码重构,高级的集成单元测试方案,和强大的解决方案内导航和搜索。实质上,ReSharper特征可用于C#,VB.NET,XML,ASP.NET,XAML,和构建脚本。ReSharper还为C#和VB.NET提供了增强的交叉语言功能,它使开发者可以有效的控制.net混合项目。
.NET5 WebApi 实现JWT及其验证实战
Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。本文只是举个例子,可以这么整,如果要用于生产环境,可能得再封装一下,注释都加的齐全,没用过的可以看看。
阿里云对象存储OSS使用STS临时授权给Browser.js
阿里云对象存储OSS(Object Storage Service)是阿里云提供的海量、安全、低成本、高可靠的云存储服务。其数据设计持久性不低于99.9999999999%(12个9),服务可用性(或业务连续性)不低于99.995%。OSS具有与平台无关的RESTful API接口,您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。如果你的应用场景仅仅是网站上传个图片、视频这些,那么阿里云OSS和七牛云的作用是一样的。
C# 对比两个实体类指定字段是否被修改并得出修改记录
需求来源:一条数据被编辑之后,日志要记录下改动了什么项,从什么改成什么了,还得可以指定某些字段,比如用户表,只要改了用户名,就记录一下日志,业务可以根据是否有修改来发送通知啊或者启用禁用啊这些操作。
MongoDb 4.2.7 配置复制(副本集replSet)实现主从同步(Windows)
MongoDB在4.0之后,增加了事务,说明Mongodb生态越来越丰富,将来肯定可以满足更多的应用场景,在用了事务之后,操作数据的时候报错,提示实例需要是副本集,这篇文章就说一下,什么是副本集,能干啥?
利用PinYinConverter实现汉字转拼音,支持多音字
汉字转拼音的需求不多,但是遇到了再去写,稍显麻烦,索性写一个辅助类放着,这里利用了Microsoft.International.Converters.PinYinConverter类库,多音字则以多种组合的方式返回给开发者。
Postman的一个小技巧 Pre-request Script的使用
Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。
5年后,我们为什么要从 Entity Framework 转到 Dapper 工具?
向来有争议的话题都是公说公的理,婆说婆的理,Entity Framework的爱好者对此可以说是嗤之以鼻,不屑一顾,而Dapper爱好者则是举双手赞成,阅之大快人心。每个人不同的阅历,社会经验,甚至对简繁的偏见都会影响对此事的看法,凡事都有优劣,取其精华而弃之糟泊,方为上策。这篇文章则将目光聚焦到Dapper。
请打开您的微信,扫一扫
留下您的脚步
最近评论