[20190524]浅谈模糊查询.txt
[20190524]浅谈模糊查询.txt
--//一台生产系统遇到监听进程莫名down的情况,3月份曾经遇到的情况,链接:http://blog.itpub.net/267265/viewspace-2638863/
--//当时的分析:内存不足(机器内存4G相对偏小),磁盘IO不足,sql语句没有很好优化,没有使用hugepages。
--//实际上最本质的问题是SQL语句,这套系统已经运行6年以上,里面一些sql采用模糊查询也就是使用like '%姓名%'之类的查询条件.
--//首先提一下监听进程莫名down的问题,该版本10.2.0.4有1个bug,导致监听down掉.要打p6139856_10204_Linux-x86-64.zip补丁.
--//实际上这个bug一般出现在内存不足CPU资源不足的情况下才会激发。
1.关于模糊查询:
--//实际上这套系统上线我就针对这个问题提出自己的建议,开发往往拿用户的需求搪塞,从用户角度讲,确实需要这样的功能.
--//比如像姓名的模糊查询,操作用户难道不知道查询的姓吗?非也,实际上大部分情况下是知道的,最多的情况下就是一些姓不会读
--//或者读不对,还有就是拼音开头是z,c,s,zh,ch,sh,j之类的翻许多页能找到(注:大部分操作人员使用紫光拼音),一些经常打的字自
--//动调整到前面)。所以讲操作人员输入姓不会打的概率很低。完全没有必要千篇一律的查询like '%姓名%'。
--//再比如查询体检编号的问题,也是使用模糊查询,这套系统是体检系统,为了与住院病人编号相互区别。编码时在开头加入'tj'标识.
--//开发为了体验用户操作的方便,也是使用模糊查询,也就是不用输入tj也可以查询。而实际上操作用户根本不领你这个情,查询条件
--//都是like '%tjNNNNN%',我一扫描共享池就能看到这样的情况。
2.我的建议:
--//实际就是给模糊查询设置一点门槛。
--//就是在边上设计一个按钮,选上就是模糊查询,执行条件变成类似就是like '%姓名%'的模糊查询,不选就是like '姓名%'的查询。这
--//样等于给用户增加一点点"难度"。而且随着数据量增加,操作人员会慢慢体会模糊查询的"很慢".
--//还有一种方式就是让操作人员直接输入%作为模糊查询,仅仅在一些地方提示用户如何操作就ok了,这样改动更小,仅仅在于一点点操
--//作人员的培训,让他们知道如何输入查询条件。
3.给开发建议:
--//从我个人角度讲我很少提出无法完成的工作,或者工作量很大的改动,即使我发现一些设计不合理,如果改动过大,我基本不提。
--//就是提也都是浪费时间。
--//有时候我想是不是开发根本不知道还是故意而为之,这样的改动很难吗?像这样的系统即使我改用hugepages,也就是支撑1,2年.
--//说不定根本撑不到那个时间,硬件已经坏了。我见过许多项目如果从性能优化或者可持续运行角度讲.基本上属于豆腐渣工程。
--//更加不能理解的是,用户最终会把这些问题莫名其妙的问题归到网络信息中心... 无语...
--//也许拯救整个系统最好的选择就是购买更好的硬件,来掩盖软件设计开发的缺陷,良好的硬件就是一块遮羞布,如此反复出现。
[20190524]浅谈模糊查询.txt的更多相关文章
- 浅谈命令查询职责分离(CQRS)模式
在常用的三层架构中,通常都是通过数据访问层来修改或者查询数据,一般修改和查询使用的是相同的实体.在一些业务逻辑简单的系统中可能没有什么问题,但是随着系统逻辑变得复杂,用户增多,这种设计就会出现一些性能 ...
- 转:浅谈命令查询职责分离(CQRS)模式
原文来自于:http://www.cnblogs.com/yangecnu/p/Introduction-CQRS.html 在常用的三层架构中,通常都是通过数据访问层来修改或者查询数据,一般修改和查 ...
- 浅谈命令查询职责分离(CQRS)模式---转载
在常用的三层架构中,通常都是通过数据访问层来修改或者查询数据,一般修改和查询使用的是相同的实体.在一些业务逻辑简单的系统中可能没有什么问题,但是随着系统逻辑变得复杂,用户增多,这种设计就会出现一些性能 ...
- 【转】浅谈命令查询职责分离(CQRS)模式
原文链接:https://www.cnblogs.com/yangecnu/p/Introduction-CQRS.html 在常用的三层架构中,通常都是通过数据访问层来修改或者查询数据,一般修改和查 ...
- 浅谈Linq查询
一.Var关键字 在学习Linq查询之前,我们先来学习var关键字的用法,看看微软官方的定义:从Visual C#3.0开始,在方法范围声明的变量可以具有隐式“类型” var.隐式类型的局部变量是强类 ...
- 浅谈oracle树状结构层级查询之start with ....connect by prior、level及order by
浅谈oracle树状结构层级查询 oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的,虽然我是一个java程序开发者,我一直觉得只 ...
- oracle树形结构层级查询之start with ....connect by prior、level、order by以及sys_connect_by_path之浅谈
浅谈oracle树状结构层级查询 oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的,虽然我是一个java程序开发者,我一直觉得只 ...
- 浅谈sql 、linq、lambda 查询语句的区别
浅谈sql .linq.lambda 查询语句的区别 LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量 ...
- 浅谈SQL优化入门:1、SQL查询语句的执行顺序
1.SQL查询语句的执行顺序 (7) SELECT (8) DISTINCT <select_list> (1) FROM <left_table> (3) <join_ ...
随机推荐
- C#基本语法<三>_WindowsFrom
winform 在windows form开发过程中还是有很多坑需要注意,包括一些重要代码记不得,在这个文件中进行汇总更新. 命名规则 M结尾表示model A结尾表示消息 Object表示 ,底层接 ...
- PostgreSQL 表字段起别名
使用Postgreq Sql 表字段起别名时注意要用双引号,使用单引号会出现语法错误,执行结果如图
- Cesium专栏-克里金插值(全国温度为例,附源码下载)
Cesium Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精 ...
- PHP对URL进行字符串编码
urlencode($url1) urldecode($url) //对URL进行字符串编码和解码 $url1 = 'https://www.baidu.com/uploade/img/123.png ...
- mysql-installer-community-8.0.17.0.msi安装教程
1.官网 https://dev.mysql.com/downloads/file/?id=488055 我选择自定义安装 注意这里是可以设置路径的,否则是默认地址 然后一直下一步就好 也是一路下一步 ...
- s3c2440裸机-UART编程(二、UART编程实现)
UART编程 1.初始化 我们的2440支持3个UART串口,以uart0为例讲解. 那么我们需要实现以下这几个函数完成串口的最基本功能: (1)uart0_init()用于初始化串口 (2)putc ...
- 给Java0基础的五个学习的思路?
关于Java初学者来说,想学习Java教程,需求了解,根底打好才干学得更好,Java教程之学习Java的路线图的五个必经阶段,希望能对Java学习者有所帮忙. 第一个阶段-java根底阶段 1.jav ...
- windows golang安装golang.org/x/net text grpc
使用git # 吧$GOPATH替换成自己的GOPATH git clone https://github.com/golang/net.git $GOPATH\src\golang.org\x\ne ...
- Go语言系列教程
一 Go介绍与开发环境搭建 01-Go语言简介 02-开发环境搭建 03-Go语言集成开发环境之GoLand安装使用 04-Go语言集成开发环境之VS Code安装使用 05-Go包管理详解 二 Go ...
- golang数据结构之快速排序
具体过程:黑色标记代表左指针,红色标记代表右指针,蓝色标记代表中间值.(依次从左往向下) //QuickSort 快速排序 func QuickSort(left ]int) { l := left ...