《SQL必知必会——第6、7、8课:用通配符进行过滤、创建计算字段、使用函数处理数据》

本文主要是介绍《SQL必知必会——第6、7、8课:用通配符进行过滤、创建计算字段、使用函数处理数据》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       第6课 用通配符进行过滤
       什么是通配符呢?本书没有具体说,相信大家都知道什么是通配符,在接触计算机过程中,通配符的概念应该早早建立了起来。我还是查了,百度百科上这么解释:“通配符是一种特殊语句,主要有星号(*)和问号(?),用来模糊搜索文件。当查找文件夹时,可以使用它来代替一个或多个真正字符;当不知道真正字符或者懒得输入完整名字时,常常使用通配符代替一个或多个真正的字符”。这个差不多就是通配符的定义了,有了这个定义,对通配符的理解也就更加清晰了。那么在sql中如何使用通配符呢?那就是结合like操作符使用。注意通配符搜索只能用于文本字段(字符串),非文本数据类型字段不能使用通配符搜索。

       百分号(%)通配符,表示任意字符出现任意次数。通配符可以出现在任意位置,并且可以使用多个通配符,比如:select id, name from products where name like '%bag%',这样name字段中包含bag字符的行都将被检索出来。但%通配符也不是万能的,并不是可以匹配任何东西,那个例外就是NULL,比如上面的例子:select id, name from products where name like '%';不会匹配名称为NULL的行。

       下划线(_)通配符,用途与用法和%一样,唯一的区别是下划线通配符只匹配单个字符,百分号通配符可以匹配多个字符。所谓一个萝卜一个坑,说的就是下划线通配符。灵活性来讲百分号通配符更强大,但查询时也会更耗时。

       方括号([])通配符,因为我看书中介绍说只有微软Access和SQL Server支持,其他DBMS不一定支持,这里就不做过多介绍了。大体用法就是把要匹配的字符放进方括号通配符,因为只能匹配单个字符,所以更多场景还需要结合其他通配符一起使用才行。

       总体上,通配符很有用,但代价是查询非常耗时,谨慎使用。

       第7课 创建计算字段
       说到字段,有一个概念上的模糊不清的地方,那就是字段和列的区别,我在看本章以前也是傻傻分不清,或者说就没想过还有区别。那就是,对于数据库而言,是没有字段概念的,只有列的概念。而对于客户端来讲,也就是从数据库查询出数据,我们叫字段,也会叫列,这个是可以互换使用的。而字段,更严格一点应该叫计算字段,因为从数据库查询数据后,在这个过程中是可以对数据进行加工或者计算的,然后将结果作为最后的输出,所以本课标题叫创建计算字段,加工或计算出来的结果就是新创建的计算字段,这些字段在数据库中是没有对应列的,这里应该就明白为什么说对于数据库而言,只有列没有字段的概念了。举个例子,数据中表中有两列:name和country,那么我们可以把这两个值拼接起来作为输出结果。比如:select name + '(' + country + ')' as title from products order by name; 这样查询的数据就不会是两列,而是返回新的字段title,即拼接好的名称和产地,这里as关键字用于创建别名。对于客户端而言,会真实的认为title就是数据库的列,但title并不是数据库中的列。上面仅仅通过加号对字段进行拼接,实际还有很多操作,比如使用trim()函数去除空格,这样一看,就会发现很多编程语言都大同小异,java中去除空格是trim()函数,js中也是。除此之外,还可以进行算术计算,比如:select id, quantity, price, quantity*price as expanded_price from products where order_num=1234; 上面的语句理解起来很简单,这么做的好处是更简介、高效,客户端直接拿结果,而无须二次计算。不过,对于简单业务逻辑还行,稍微复杂一点的业务不建议这么做,灵活性不高、维护成本却高,还不便于测试。sql还是越简单越好,不要把业务逻辑写进sql。

       第8课 使用函数处理数据
       这一课可以说是第7课的延伸,第7课提到了在创建计算字段时,会使用一些函数,比如trim()去除字符串左右两边空格,本课继续介绍其他函数。对于文本,还有upper()和lower(),将字符串转为大写或者小写,length()返回字符串长度,等等;对于日期和时间,比如从日期中提取年份,有year(),日期加减有date_add()、date_sub()等;对于数值处理,有取绝对值abs(),计算平方根sqrt(),计算指数exp()等。这里就不一一介绍了,主要大家知道有这么一回事就行了,具体场景可以单独查某个函数用法。另外,不同的dbms,都会提供上述函数的功能,但函数名称可能不一样。

 

 

这篇关于《SQL必知必会——第6、7、8课:用通配符进行过滤、创建计算字段、使用函数处理数据》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114957

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后