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
关于C#执行Mysql创建存储过程脚本@符号的问题处理
在项目中遇到了需要代码执行创建存储过程的需求,但是因为在存储过程有时候需要用到变量,用到了@符号,这时候发现MySqlCommand执行报错,提示需要给这个带艾特的参数赋值,意思是他当成了sqlparameter处理了,就是我们防止注入的那个东西。这篇文章介绍一下另外的一个方案,让我们可以实现用代码执行带@符号的sql语句。
一步一个脚印 20170313
4个月后,刚刚好两年了。我一直记得第一天是2015年7月13号。大学开学的时候,怀着期待与忐忑的心情,来成都报道;对新的环境充满好奇,认识新朋友,新目标,新动力。我们出发了。刚入校园感觉一切都很和谐,每个人都有鲜明的特点和明确的目标,可能是因为这里是高考失败集中营。
Postman的一个小技巧 Pre-request Script的使用
Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。
.NET C# 10.0中命令空间(namespace)的新写法及提示警告配置
C#10中,更新了很多新的语法,但是在项目中,每个人如果写的不一样,就会造成团队代码风格不统一,这样很不好管理,那么就需要来约束大家的代码风格一致,本文记录了如何配置项目,可以让代码风格一致
.net平台下利用Quartz实现高可用的任务调度
接触Quartz.net也是因为之前用的Time组件不是很稳定,发现Time组件跑一段时间,就出现假死不动了,导致任务调度中断,本文主要记录使用的案例。
windows环境下Redis安装
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
疫情数据关注工具-支持全平台版本(12月15停止更新,一个时代的结束)
疫情形式严峻,我十分关心每天的疫情动态,但是我发现无论是百度的疫情动态,还是腾讯的动态,数据都不完整,而且腾讯的风险地区更新不及时,导致经常看到错误数据。
.NET WebApi配置Swagger详细教程
Swagger可以根据xml文件生成api接口文档,前后端节约沟通时间,减少对接成本,是一个非常好的解决方案;本文主要记录一下,Vs2019从0开始,搭建一个WebApi最终利用Swagger看到相关接口,并解决Swagger汉化的问题,解决Swagger在.net Webapi中控制器名称标注问题。
《灵笼》白月魁 壁纸
国漫《灵笼》特别篇播出,作为第一季的大结局剧情,灵笼在最后一话的特别篇中终于把地面神秘人物白月魁的身份信息给揭露了出来,原来之前马克队长猜得没有错,当时在下到地面采集物资的时候,看到的女子其实就是白月魁小队,她们是生活在地面的人类,但是从本质而言,似乎已经和人类有所区别。
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混合项目。
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数据库。
.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和七牛云的作用是一样的。
Visual Studio生成注释的插件GhostDoc,支持2022
GhostDoc为Visual Studio中的C#代码编辑器安装了一个新的命令。在编辑源文件时,只需将光标置于要添加文档的方法或属性内部,然后通过热键(默认为Ctrl+Shift+D)或右键菜单中的Document this菜单项调用命令,GhostDoc就会插入一段XML格式的注释。你也许会想到在方法或属性前面键入"///"时的类似效果,但是后者只能创建一段空的注释构造,而GhostDoc则能够生成大部分实用的注释。
C# 对比两个实体类指定字段是否被修改并得出修改记录
需求来源:一条数据被编辑之后,日志要记录下改动了什么项,从什么改成什么了,还得可以指定某些字段,比如用户表,只要改了用户名,就记录一下日志,业务可以根据是否有修改来发送通知啊或者启用禁用啊这些操作。
MongoDb 4.2.7 配置复制(副本集replSet)实现主从同步(Windows)
MongoDB在4.0之后,增加了事务,说明Mongodb生态越来越丰富,将来肯定可以满足更多的应用场景,在用了事务之后,操作数据的时候报错,提示实例需要是副本集,这篇文章就说一下,什么是副本集,能干啥?
Postman的一个小技巧 Pre-request Script的使用
Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。
利用PinYinConverter实现汉字转拼音,支持多音字
汉字转拼音的需求不多,但是遇到了再去写,稍显麻烦,索性写一个辅助类放着,这里利用了Microsoft.International.Converters.PinYinConverter类库,多音字则以多种组合的方式返回给开发者。
请打开您的微信,扫一扫
留下您的脚步
最近评论