SQL数据库开发—TSQL-—运算符2不常用

2024-03-05 08:38

本文主要是介绍SQL数据库开发—TSQL-—运算符2不常用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一 select 运算符优先级

级别    运算符
0    ()
1    ~(位非)
2    *(乘)、/(除)、%(取模)
3    +(正)、-(负)、+(加)、+(串联)、-(减)、&(位与)、^(位异或)、|(位或)
4    =、>、<、>=、<=、<>、!=、!>、!<(比较运算符)
5    NOT
6    和
7    ALL、ANY、BETWEEN、IN、LIKE、OR、SOME
8    =(赋值)
 

 

二  位运算符 (Transact-SQL)

位运算符的操作数可以是整数或二进制字符串数据类型类别中的任何数据类型(image 数据类型除外),但两个操作数不能同时是二进制字符串数据类型类别中的某种数据类型。 下表显示所支持的操作数数据类型。

  • &(位与)               如果两个位置上的位均为 1,则结果为 1。
  • &=(位与赋值)
  • |(位或)                  如果两个位置上任意一个位置的位为 1,则结果为 1。
  • |=(位或赋值)
  • ^(位异或)             对每个位位置上的位值取反。
  • ^=(位异或赋值)

 

运算符后的表达式位运算

如果两个位置上的位均为 1,则结果为 1。
1010 1010 = 170 
0100 1011 = 75 
----------------- 
0000 1010 = 10
或 
如果两个位置上任意一个位置的位为 1,则结果为 1。
1010 1010 = 170 
0100 1011 = 75 
----------------- 
1110 1011 = 235
NOT 
对每个位位置上的位值取反。
1010 1010 = 170 
----------------- 
0101 0101 = 85
  • 位运算符的操作数可以是整数或二进制字符串数据类型类别中的任何数据类型(image 数据类型除外),但两个操作数不能同时是二进制字符串数据类型类别中的某种数据类型。 下表显示所支持的操作数数据类型。

左操作数右操作数
binaryint、smallint 或 tinyint
bitint、smallint、tinyint 或 bit
intint、smallint、tinyint、binary 或 varbinary
smallintint、smallint、tinyint、binary 或 varbinary
tinyintint、smallint、tinyint、binary 或 varbinary
varbinaryint、smallint 或 tinyint

三 字符串运算符

3.1 +(字符串串联)(Transact-SQL)

字符和二进制数据类型类别中的任何一个数据类型的有效表达式,但 image、ntext 或 text 数据类型除外。 两个表达式必须具有相同的数据类型,或者其中一个表达式必须能够隐式转换为另一个表达式的数据类型。

SELECT user_name + '_' + USER_PWD s FROM A70_USERS_ZH

张春生_4959
朱艳平_4926

 

SELECT 'The order is due on ' + CONVERT(varchar(12), DueDate, 101)  
FROM Sales.SalesOrderHeader  
WHERE SalesOrderID = 50001;  
GO  

下面是结果集:

------------------------------------------------  
The order is due on 04/23/2007  
(1 row(s) affected)

 

3.2 +=(字符串串联赋值)(Transact-SQL)

将两个字符串串联起来并将一个字符串设置为运算结果。 例如,如果变量 @x 等于 'Adventure',则 @x += 'Works' 会接受 @x 的原始值,将 'Works' 添加到该字符串中并将 @x 设置为该新值 'AdventureWorks'。

DECLARE @v1 varchar(40);  
SET @v1 = 'This is the original.';  
SET @v1 += ' More text.';  
PRINT @v1;  

下面是结果集:

This is the original. More text.

3.3 %百分比字符(通配符 - 需匹配的字符)(Transact-SQL)

3.4 [ ](通配符 - 要匹配的字符)(Transact-SQL)

匹配指定范围内或者属于方括号 [ ] 所指定的集合中的任意单个字符。 可以在涉及模式匹配的字符串比较(例如,LIKE 和 PATINDEX)中使用这些通配符。

 

复制

SELECT name FROM sys.databases
WHERE name LIKE 'm[n-z]%';

下面是结果集:

复制

name
-----
model
msdb

 

3.5 [^](通配符 - 无需匹配的字符)(Transact-SQL)

匹配不在方括号之间指定的范围或集合内的任何单个字符。

示例

下面的示例使用 [^] 运算符在 Contact 表中查找所有名字以 Al 开头且第三个字母不是字母 a 的所有人。

- Uses AdventureWorks SELECT FirstName, LastName FROM Person.Person WHERE FirstName LIKE 'Al[^a]%' ORDER BY FirstName;

3.6 通配符 - 匹配一个字符)(Transact-SQL)

下划线字符 用于匹配涉及模式匹配的字符串比较操作(如 LIKE 和 PATINDEX)中的任何单个字符。

 

SQL复制

SELECT name FROM sys.databases
WHERE name LIKE 'm_d%';

下面是结果集:

复制

name
-----
model
msdb

这篇关于SQL数据库开发—TSQL-—运算符2不常用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v