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
服务端高并发分布式架构演进之路
本文以淘宝作为例子,介绍从一百个到千万级并发情况下服务端的架构的演进过程,同时列举出每个演进阶段会遇到的相关技术,让大家对架构的演进有一个整体的认知,文章最后汇总了一些架构设计的原则。
短链接生成算法
早期短链接广泛应用于图片上传网站,通过缩短网址URL链接字数,达到减少代码字符串的目的。更便于使用者引用网址,写入代码中。节省字符数空间。常见于网店图片分类的使用,因有字符限制,运用短链接,达到外链图片的目的,自微博盛行以来,在微博字数有限的特色下,短链接也盛行于微博网站,以节省字数,给博主发布更多文字的空间。
EFcore+MySql 数据迁移的时候,怎么给表结构加注释?
Microsoft.EntityFrameworkCore是一个非常不错的设计,当一套系统里面出现太多的SQL,其实已经不合理了,所以EF让开发者不再接触SQL,而是直接以对象形式操作数据库,EF来负责Sql代码生成和执行,通常在开发中,有根据数据表结构来生成实体的,也有根据实体生成数据库的,就是所谓的DbFirst和CodeFirst,这篇文章主要说一下CodeFirst的应用,用的是MySql数据库。
.net 实现Socket通信(第一种方式)
Socket的英文原义是“孔”或“插座”。作为BSD UNIX的进程通信机制,取后一种意思。通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信。在Internet上的主机一般运行了多个服务软件,同时提供几种服务。每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务。Socket正如其英文原义那样,像一个多孔插座。一台主机犹如布满各种插座的房间,每个插座有一个编号,有的插座提供220伏交流电, 有的提供110伏交流电,有的则提供有线电视节目。 客户软件将插头插到不同编号的插座,就可以得到不同的服务。
解决WordPress无法发送邮件的方法
当我测试找回密码的功能的时候,发现提示发送失败,原因可能是你的服务器禁用了mail()方法。本来想修复,最后想了下,算了,直接简单粗暴的替换掉他的发送方法,用我们自己的方法,去调用别人的smtp服务器来完成发送操作。将以下代码放在主题文件夹里面的functions.php里面保存即可
.NET下对MongoDb的认识和使用
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
使用NPOI封装能用于绝大部分场景的导出Execl文件的辅助类
NPOI生成的文件能和Office编码一样,而且创建文件和写入数据很快,这是他的优点;今天我们分享的是利用NPOI来封装一个适用于大多数场景的导出辅助类。
二、Electron 之electron-forge脚手架使用
electron-forge脚手架能帮助我们快速搭建和开发我们的应用,它集成了很多快捷功能,但是缺点也很明显,所以本篇文章只记录如何使用,后期会讲解Vite脚手架
EntityFrameworkCore数据加密存储解决方案
我们平时项目中,有很多数据其实是需要加密存储的,但是我们基本上都只是将密码进行加密存储,如果我们的用户银行卡信息,身份证信息,这些要进行明文显示,但是如果数据泄露,也能保护用户数据的就更好了,今天给大家介绍的就是这样的一个解决方案。
.NET WebApi配置Swagger详细教程
Swagger可以根据xml文件生成api接口文档,前后端节约沟通时间,减少对接成本,是一个非常好的解决方案;本文主要记录一下,Vs2019从0开始,搭建一个WebApi最终利用Swagger看到相关接口,并解决Swagger汉化的问题,解决Swagger在.net Webapi中控制器名称标注问题。
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中控制器名称标注问题。
《灵笼》白月魁 壁纸
国漫《灵笼》特别篇播出,作为第一季的大结局剧情,灵笼在最后一话的特别篇中终于把地面神秘人物白月魁的身份信息给揭露了出来,原来之前马克队长猜得没有错,当时在下到地面采集物资的时候,看到的女子其实就是白月魁小队,她们是生活在地面的人类,但是从本质而言,似乎已经和人类有所区别。
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和七牛云的作用是一样的。
C# 对比两个实体类指定字段是否被修改并得出修改记录
需求来源:一条数据被编辑之后,日志要记录下改动了什么项,从什么改成什么了,还得可以指定某些字段,比如用户表,只要改了用户名,就记录一下日志,业务可以根据是否有修改来发送通知啊或者启用禁用啊这些操作。
MongoDb 4.2.7 配置复制(副本集replSet)实现主从同步(Windows)
MongoDB在4.0之后,增加了事务,说明Mongodb生态越来越丰富,将来肯定可以满足更多的应用场景,在用了事务之后,操作数据的时候报错,提示实例需要是副本集,这篇文章就说一下,什么是副本集,能干啥?
Visual Studio生成注释的插件GhostDoc,支持2022
GhostDoc为Visual Studio中的C#代码编辑器安装了一个新的命令。在编辑源文件时,只需将光标置于要添加文档的方法或属性内部,然后通过热键(默认为Ctrl+Shift+D)或右键菜单中的Document this菜单项调用命令,GhostDoc就会插入一段XML格式的注释。你也许会想到在方法或属性前面键入"///"时的类似效果,但是后者只能创建一段空的注释构造,而GhostDoc则能够生成大部分实用的注释。
Postman的一个小技巧 Pre-request Script的使用
Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。
利用PinYinConverter实现汉字转拼音,支持多音字
汉字转拼音的需求不多,但是遇到了再去写,稍显麻烦,索性写一个辅助类放着,这里利用了Microsoft.International.Converters.PinYinConverter类库,多音字则以多种组合的方式返回给开发者。
NPOI导出Excel,包含一个或者多个sheet表
NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作。NPOI是一个开源的C#读写Excel、WORD等微软OLE2组件文档的项目。他导出的文件和你电脑右键创建的office文件一样原生,不会提示格式不符,重要的是不依赖office组件。
请打开您的微信,扫一扫
留下您的脚步
最近评论