SQL 算术运算符:加法、减法、乘法、除法和取模的用法

小万哥
• 阅读 331

SQL Server中的存储过程

什么是存储过程?

存储过程是一段预先编写好的 SQL 代码,可以保存在数据库中以供反复使用。它允许将一系列 SQL 语句组合成一个逻辑单元,并为其分配一个名称,以便在需要时调用执行。存储过程可以接受参数,使其更加灵活和通用。

存储过程语法

创建存储过程的语法如下:

CREATE PROCEDURE 存储过程名称
AS
SQL语句
GO;

执行存储过程的语法如下:

EXEC 存储过程名称;

演示数据库

以下是 Northwind 示例数据库中 "Customers" 表的部分内容:

CustomerID CustomerName ContactName Address City PostalCode Country
1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico
4 Around the Horn Thomas Hardy 120 Hanover Sq. London WA1 1DP UK
5 Berglunds snabbköp Christina Berglund Berguvsvägen 8 Luleå S-958 22 Sweden

存储过程示例

以下 SQL 语句创建了一个名为 "SelectAllCustomers" 的存储过程,用于从 "Customers" 表中选择所有记录:

CREATE PROCEDURE SelectAllCustomers
AS
SELECT * FROM Customers
GO;

执行上述存储过程的方法如下:

EXEC SelectAllCustomers;

带有一个参数的存储过程

以下 SQL 语句创建了一个存储过程,该过程从 "Customers" 表中选择特定城市的客户:

CREATE PROCEDURE SelectAllCustomers @City nvarchar(30)
AS
SELECT * FROM Customers WHERE City = @City
GO;

执行上述存储过程的方法如下:

EXEC SelectAllCustomers @City = 'London';

带有多个参数的存储过程

设置多个参数非常简单。只需逐个列出每个参数及其数据类型,用逗号分隔。

以下 SQL 语句创建了一个存储过程,该过程从 "Customers" 表中选择特定城市和特定邮政编码的客户:

CREATE PROCEDURE SelectAllCustomers @City nvarchar(30), @PostalCode nvarchar(10)
AS
SELECT * FROM Customers WHERE City = @City AND PostalCode = @PostalCode
GO;

执行上述存储过程的方法如下:

EXEC SelectAllCustomers @City = 'London', @PostalCode = 'WA1 1DP';

SQL 注释用于提供对 SQL 语句的解释,或者在调试和维护过程中临时禁用某些语句。注释不会被数据库执行。

单行注释

单行注释以 -- 开头,后面的文本将被注释掉。

-- 这是单行注释
SELECT * FROM Customers;

在单行注释中,-- 后面的文本会被忽略。

单行注释在语句末尾

SELECT * FROM Customers -- WHERE City='Berlin';

在这个例子中,-- 后面的文本和语句末尾的内容都被忽略。

多行注释

多行注释以 /* 开头,以 */ 结尾,之间的所有文本都被注释掉。

/* 这是
多行注释 */
SELECT * FROM Customers;

在多行注释中,/**/ 之间的文本都被忽略。

多行注释忽略多条语句

/* SELECT * FROM Customers;
SELECT * FROM Products;
SELECT * FROM Orders;
SELECT * FROM Categories; */
SELECT * FROM Suppliers;

在这个例子中,/**/ 之间的所有语句都被注释掉。

部分注释

要仅忽略语句的一部分,可以在适当位置使用 /* */ 注释。

SELECT CustomerName, /*City,*/ Country FROM Customers;

在这个例子中,/**/ 之间的 City 列会被注释掉,而其他部分保持不变。

部分注释语句

SELECT * FROM Customers WHERE (CustomerName LIKE 'L%'
OR CustomerName LIKE 'R%' /*OR CustomerName LIKE 'S%'
OR CustomerName LIKE 'T%'*/ OR CustomerName LIKE 'W%')
AND Country='USA'
ORDER BY CustomerName;

在这个例子中,/**/ 之间的部分条件被注释掉,但其他条件保持不变。

SQL 算术运算符

加法 (**+**): 用于将两个值相加。

SELECT column1 + column2 AS SumResult FROM tableName;

减法 (**-**): 用于从第一个值中减去第二个值。

SELECT column1 - column2 AS Difference FROM tableName;

乘法 (*****): 用于将两个值相乘。

SELECT column1 * column2 AS Product FROM tableName;

除法 (**/**): 用于将第一个值除以第二个值。

SELECT column1 / column2 AS Quotient FROM tableName;

取模 (**%**): 返回除法的余数。

SELECT column1 % column2 AS Modulus FROM tableName;

SQL 位运算符

按位与 (**&**): 对二进制数进行按位与运算。

SELECT column1 & column2 AS BitwiseAND FROM tableName;

按位或 (**|**): 对二进制数进行按位或运算。

SELECT column1 | column2 AS BitwiseOR FROM tableName;

按位异或 (**^**): 对二进制数进行按位异或运算。

SELECT column1 ^ column2 AS BitwiseXOR FROM tableName;

SQL 比较运算符

等于 (**=**): 判断两个值是否相等。

SELECT column1 FROM tableName WHERE column1 = column2;

大于 (**>**): 判断一个值是否大于另一个值。

SELECT column1 FROM tableName WHERE column1 > column2;

小于 (**<**): 判断一个值是否小于另一个值。

SELECT column1 FROM tableName WHERE column1 < column2;

大于等于 (**>=**): 判断一个值是否大于或等于另一个值。

SELECT column1 FROM tableName WHERE column1 >= column2;

小于等于 (**<=**): 判断一个值是否小于或等于另一个值。

SELECT column1 FROM tableName WHERE column1 <= column2;

不等于 (**<>** 或 **!=**): 判断两个值是否不相等。

SELECT column1 FROM tableName WHERE column1 <> column2;

SQL 复合运算符

复合运算符是一组用于执行多个操作的运算符。

加等于 (**+=**): 将右侧的值添加到左侧的值,并将结果分配给左侧的值。

UPDATE tableName SET column1 += 10 WHERE condition;

减等于 (**-=**): 从左侧的值中减去右侧的值,并将结果分配给左侧的值。

UPDATE tableName SET column1 -= 5 WHERE condition;

乘等于 (***=**): 将左侧的值乘以右侧的值,并将结果分配给左侧的值。

UPDATE tableName SET column1 *= 2 WHERE condition;

除等于 (**/=**): 将左侧的值除以右侧的值,并将结果分配给左侧的值。

UPDATE tableName SET column1 /= 3 WHERE condition;

取模等于 (**%=**): 将左侧的值除以右侧的值并取余数,结果分配给左侧的值。

UPDATE tableName SET column1 %= 4 WHERE condition;

SQL 逻辑运算符

逻辑运算符用于连接和改变条件语句的逻辑关系。

AND: 如果由 AND 分隔的所有条件都为 TRUE,则为 TRUE

SELECT * FROM tableName WHERE condition1 AND condition2;

OR: 如果由 OR 分隔的任何条件都为 TRUE,则为 TRUE

SELECT * FROM tableName WHERE condition1 OR condition2;

NOT: 如果条件不为 TRUE,则显示记录。

SELECT * FROM tableName WHERE NOT condition;

以上 ANDORNOT 可以结合使用,以满足更复杂的查询需求。

最后

为了方便其他设备和平台的小伙伴观看往期文章:公众号搜索Let us Coding,或者扫描下方二维码,关注公众号,即可获取最新文章。

看完如果觉得有帮助,欢迎点赞、收藏关注

SQL 算术运算符:加法、减法、乘法、除法和取模的用法

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
Mysql优化
一、存储过程1.1、什么是存储过程  就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法。ps:存储过程跟触发器有点类似,都是一组SQL集,但是存储过程是主动调用的,且功能比触发器更加强大,触发器是某件事触发后自动调用。1.2、存储过程有哪些特性  有输入输出参数,可
Wesley13 Wesley13
3年前
MySQL管理与优化(9):存储过程和函数
存储过程和函数存储过程和函数是事先经过编译并存储在数据库中的一段SQL语句的集合。存储过程或函数的相关操作创建,修改存储过程或函数相关语法CREATEDEFINER{user|CURRENT_USER}PROCE
Wesley13 Wesley13
3年前
mysql——定义——存储过程和函数——概念
存储过程和函数是指将经常使用的一组SQL语句组合在一起,并将这些SQL语句当作一个整体存储在服务器中一、创建存储过程语法格式:createproceduresp_name(proc_parameter……)ch
Wesley13 Wesley13
3年前
mysql存储过程和自定义函数
存储过程简介SQL语句需要先编辑后执行,而存储过程是一组为了完成特定功能的SQL语句集,经编译后存储过程在数据库中,用户通过制定存储过程的名字并传给参数来调用它。存储过程是可编程的函数,在数据库中创建并保持,可以由SQL和控制结构组成。档想要在不同的应用平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的,数据库中的存储过程可以看错
Easter79 Easter79
3年前
SQL Server数据库基础知识——存储过程
SQLServer数据库基础知识存储过程概述什么是存储过程?存储过程的种类如何创建、修改、删除、调用存储过程?存储过程的优缺点存储过程和触发器的区别?存储过程和函数的区别?
Wesley13 Wesley13
3年前
Oracle存储过程创建及Java调用
在大型数据库系统中,有两个很重要作用的功能,那就是存储过程和触发器。在数据库系统中无论是存储过程还是触发器,都是通过SQL语句和控制流程语句的集合来完成的。相对来说,数据库系统中的触发器也是一种存储过程。存储过程在数据库中运算时自动生成各种执行方式,因此,大大提高了对其运行时的执行速度。在大型数据库系统如Oracle、SQLServer中都不仅提供了
Wesley13 Wesley13
3年前
Mysql存储过程
SQL语句需要先编译然后执行,而存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。存储过程是可编程的函数,在数据库中创建并保存,可以由SQL语句和控制结构组成。当想要在不同的应用程序或平台上执行相同的函数,或者封装特定功能时
Wesley13 Wesley13
3年前
MySQL存储过程详解
点击关注上方“SQL数据库开发”,设为“置顶或星标”,第一时间送达干货经常有小伙伴问我这个存储过程该如何写?作为过来人我刚开始也有这样的苦恼,今天就给大家说说这个存储过程该如何创建和使用。什么是存储过程存储过程是一组可编程的函数,是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户
Wesley13 Wesley13
3年前
mysql存储过程和函数(一)
  存储过程和函数是事先经过编译并存储在数据库的一段sql语句集合,调用存储过程和函数可以简化应用程序开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对提高数据运行效率是有好处的。  存储过程和函数的区别在于函数必须有返回值,而存储过程却没有,存储过程的参数可以使用IN,OUT,INOUT类型,而函数的参数只能使用IN类型,  在对存储过
Wesley13 Wesley13
3年前
Oracle存储过程
1、定义所谓存储过程(StoredProcedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过编译后存储在数据库系统中。在使用时候,用户通过指定已经定义的存储过程名字并给出相应的存储过程参数来调用并执行它,从而完成一个或一系列的数据库操作。2、存储过程的创建Oracle存储过程包含三部分