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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间