求sql语句。得出表中两列相减的值

表1中,列A减列B每一行都得出结果

1、语句如下:

select A, B, A-B as C from 表1

2、计算列:

可以使用同一表中的其他列的表达式计算得来。表达式可以是非计算列的列名、常量、函数,也可以是用一个或多个运算符连接的上述元素的任意组合。表达式不能为子查询。

语句中的A-B就是计算列,as C的意思是给这个计算列起个列名叫C。

只要符合上述规则,你可以任意组合字段、运算符等,形成需要的计算列。

扩展资料:

计算列应用范围

计算列可用于选择列表、WHERE 子句、ORDER BY 子句或任何可使用正则表达式的其他位置,但下列情况除外:

用作 CHECK、FOREIGN KEY 或 NOT NULL 约束的计算列必须标记为 PERSISTED。如果计算列的值由具有确定性的表达式定义,并且索引列中允许使用计算结果的数据类型,则可将该列用作索引中的键列,或者用作 PRIMARY KEY 或 UNIQUE 约束的一部分。

例如,如果表中含有整数列 a 和 b,则可以对计算列 a + b 创建索引,但不能对计算列 a + DATEPART(dd, GETDATE()) 创建索引,因为在后续调用中,其值可能发生改变。

计算列不能作为 INSERT 或 UPDATE 语句的目标。

数据库引擎基于使用的表达式自动确定计算列的为 Null 性。即使只有非空列,大多数表达式的结果也“认为”可为空值,因为下溢或溢出生成的结果也可能为空。使用带 AllowsNull 属性的 COLUMNPROPERTY 函数可查明表中任何计算列的为 Null 性。通过指定 ISNULL (check_expression, constant) 可以将可为空值的表达式转换为不可为空值的表达式,其中, constant 是可替换所有空结果的非空值.

参考资料:

百度百科.计算列

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-11-22
楼上说的都不对,如果有空值的话,那样想减还是空值,应该这样:

SELECT isnull(A,0)-isnull(B,0) AS 结果 FROM 表 --sqlserver语法

SELECT nvl(A,0)-nvl(B,0) AS 结果 FROM 表 --Oracle语法

SELECT ifnull(A,0)-ifnull(B,0) AS 结果 FROM 表 --mysql语法

以上,希望对你有所帮助本回答被提问者采纳
第2个回答  2009-08-21
SELECT A-B AS 结果 FROM 表;
第3个回答  2009-08-21
SELECT A-B AS 结果 FROM 表;
第4个回答  2009-08-21
select (A-B) as cha from table
相似回答