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

相关文章

mysqld_multi在Linux服务器上运行多个MySQL实例

《mysqld_multi在Linux服务器上运行多个MySQL实例》在Linux系统上使用mysqld_multi来启动和管理多个MySQL实例是一种常见的做法,这种方式允许你在同一台机器上运行多个... 目录1. 安装mysql2. 配置文件示例配置文件3. 创建数据目录4. 启动和管理实例启动所有实例

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用