SQL 中的幂运算主要使用 POW() 或 POWER() 函数,两者功能相同。
-- 两种写法等价
POW(base, exponent) -- base: 底数,exponent: 指数
POWER(base, exponent)
-- 计算 2 的 3 次方
SELECT POW(2, 3); -- 返回 8
SELECT POWER(2, 3); -- 返回 8
-- 计算平方和立方
SELECT
POWER(4, 2) as square, -- 16
POW(4, 3) as cube; -- 64
| 数据库 | 函数支持 | 备注 |
|---|---|---|
| MySQL | ✅ 支持 POW() 和 POWER() | 两者完全等价 |
| PostgreSQL | ✅ 支持 POWER() | 也支持 ^ 运算符: SELECT 2 ^ 3; |
| SQL Server | ✅ 支持 POWER() | 只支持 POWER() |
| Oracle | ✅ 支持 POWER() | 使用 POWER() 函数 |
| SQLite | ✅ 支持 POW() | 也可用 * 运算符自行计算 |
-- 本金1000,年利率5%,存3年
SELECT 1000 * POWER(1.05, 3) as future_value;
-- 分列显示各年金额
SELECT
year,
1000 * POWER(1.05, year) as amount
FROM (VALUES (1), (2), (3)) as years(year);
-- 计算圆的面积: πr²
SELECT PI() * POWER(radius, 2) as circle_area
FROM circles;
-- 计算立方体体积
SELECT POWER(side_length, 3) as cube_volume
FROM cubes;
-- 将二进制转换为十进制
SELECT
binary_str,
SUM(SUBSTR(binary_str, -n, 1) * POWER(2, n-1)) as decimal_value
FROM binary_table
CROSS JOIN generate_series(1, length(binary_str)) as n;
-- 指数为 0
SELECT POWER(5, 0); -- 返回 1 (任何数的0次方等于1)
SELECT POWER(0, 0); -- 通常返回 1 (但可能因数据库而异)
-- 负指数 (计算倒数)
SELECT POWER(2, -1); -- 返回 0.5 (2的-1次方)
SELECT POWER(4, -2); -- 返回 0.0625 (1/16)
-- 分数指数 (开方)
SELECT POWER(27, 1.0/3); -- 返回 3 (立方根)
SELECT POWER(16, 0.5); -- 返回 4 (平方根)
POWER(x, 0.5) 等价于 SQRT(x):
SELECT
POWER(25, 0.5), -- 5.0
SQRT(25); -- 5.0
x * x 比 POWER(x, 2) 更快
数据类型:结果的数据类型通常与输入类型一致或为浮点数
错误处理:SELECT POWER(-4, 0.5); -- 可能返回 NULL 或错误 (负数的平方根)
SELECT POWER(0, -2); -- 可能返回错误 (0的负指数次方未定义)
-- 案例1: 计算距离 (欧几里得距离)
SELECT
SQRT(POWER(x2 - x1, 2) + POWER(y2 - y1, 2)) as distance
FROM coordinates;
-- 案例2: 指数增长模型
SELECT
year,
initial_value * POWER(growth_rate, year) as projected_value
FROM growth_model;
-- 案例3: 信号强度计算 (平方反比定律)
SELECT
source_power / POWER(distance, 2) as signal_strength
FROM signal_measurements;
POW() 和 POWER() 功能完全相同,选择取决于数据库支持和编码规范