《MySQL必知必会》通配符 ( like , % , _ ,)
《MySQL必知必会》通配符 ( like , % , _ ,)
关键字 LIke
WHERE 搜索子句中使用通配符,必须使用 LIKE 操作符。
% 百分号通配符
% 表示任意字符出现任意次数。(这里的任意当然包括 0 、1、无数)
select prod_id,prod_name
from products
where prod_name like 'jet%';
注意: 通配符搜索是可以区分大小写的。
使用关键字 Binary 即可
select prod_id,prod_name
from products
where prod_name like binary '%S%';
select prod_id,prod_name
from products
where prod_name like binary '%s%';
show viriables like '%lower%';
查看是否区分大小写;
ower_case_table_names参数详解:
lower_case_table_names = 0
其中 0:区分大小写,1:不区分大小写
MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:
1、数据库名与表名是严格区分大小写的;
2、表的别名是严格区分大小写的;
3、列名与列的别名在所有的情况下均是忽略大小写的;
4、变量名也是严格区分大小写的;修改不区分大小写,在my.cnf中的[mysqld]后面添加lower_case_table_names=1,重启MYSQL服务
从上面例子也可以看到,是可以使用多个 ‘ % ’ 通配符进行搜索的。
注意,如果以上例子替换为 ‘%anvil ’ ,anvil 后跟一个空格,那将不会匹配到以上结果,为空格会干扰通配符匹配,这可以通过使用函数取出为空格。
like concat('%','anvil','%');
上一章说到 NULL ,同样 NULL 不能作为有效值被 % 匹配到,NULL 对于数据库来说是未知的,自然不能下定论 NULL 是否匹配。
_ 下划线通配符
_ 只匹配单个字符。
select prod_id,prod_name
from products
where prod_name like binary '_ ton anvil';
再次重申 , _ 总是匹配一个字符,不能多也不能少。
使用通配符的注意事项
正如所见,MySQL的通配符很有用。但这种功能是有代价的:通配符搜索的处理一般要比前面讨论的其他搜索所花时间更长。这里给出一些使用通配符要记住的技巧。
- 不要过度使用通配符。如B果其他操作符能达到相同的目的,应该使用其他操作符。
- 在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
- 仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。
不要过度使用通配符
不要过度使用通配符
不要过度使用通配符
以后的函数将搜索会做到更好的处理,更高的性能。
最新文章
- Yii 2.x 日志记录器-类图
- PHP 自动加载规范PSR-4
- JavaScript模板引擎原理,几行代码的事儿
- Linux-001-nmon系统性能监控工具的使用及报表产出
- jquery中的 ajax 以及map遍历
- nginx 学习笔记【持续更新...】
- poj3308 Paratroopers --- 最小点权覆盖-&;gt;最小割
- [2017.02.04] C++学习记录(1)
- Java程序员的C++回归路(一)
- JavaSE-基本数据类型
- Executor介绍
- Mysql 数据库增删改查
- python爬取微信信息--显示性别/地域/词云(附代码)
- JAVAWEB 一一SpringMVC(XML配置)
- 案例导入和导出Scott用户
- cocos2d-x 3.0正式版 cmd创建project以及一键创建project
- HDU1002 A + B Problem II 大数问题
- 网络安全之——DNS欺骗实验
- JDBC增加、更新、删除数据
- 020.2.5 Calender对象
热门文章
- Springboot整合SpringSecurity--对静态文件进行权限管理
- 一款直击痛点的优秀http框架,让我超高效率完成了和第三方接口的对接
- 聊一聊Flutter的setState()
- APP自动化 -- 获取toast元素的文本内容
- 2. 妈呀,Jackson原来是这样写JSON的
- [leetcode/lintcode 题解] 谷歌面试题:找出有向图中的弱连通分量
- Android实现EditText插入表情、超链接等格式
- Redis的持久化之RDB
- PHP xml_parse_into_struct() 函数
- EACCES: permission denied,mkdir … npm install 安装依赖问题解决