当前位置: 首页 > news >正文

PostgreSQL函数和运算符

PostgreSQL为内置的数据类型提供了大量的函数和运算符,用户也可以定义自己的函数和运算符,使用psql命令\df\do可以列出所有可用的函数和运算符

1. 逻辑运算符

常用的逻辑运算符有AND、OR、NOT,逻辑系统有三个值true、fase和null,运算关系如下表所示:

aba AND ba OR b
TRUETRUETRUETRUE
TRUEFALSEFALSETRUE
TRUENULLNULLTRUE
FALSEFALSEFALSEFALSE
FALSENULLFALSENULL
NULLNULLNULLNULL
aNOT a
TRUEFALSE
FALSETRUE
NULLNULL

2. 比较函数和运算符

2.1. 运算符

常用的比较运算符如下表所示:

运算符描述
<小于
>大于
<=小于等于
>=大于等于
=等于
<>不等于
!=不等于

2.2. 比较谓词

另外,还有一些用于比较运算的谓词,如下所示:

谓词说明示例
BETWEEN AND包括范围端点2 BETWEEN 1 AND 3 --> t
2 BETWEEN 3 AND 1 --> f
NOT BETWEEN AND2 NOT BETWEEN 1 AND 3 --> f
BETWEEN SYMMETRIC AND两个端点值排序后比较2 BETWEEN SYMMETRIC 3 AND 1 --> t
NOT BETWEEN SYMMETRIC AND2 NOT BETWEEN SYMMETRIC 3 AND 1 --> f
IS DISTINCT FROM不相等,将null视为可比值1 IS DISTINCT FROM NULL --> t
NULL IS DISTINCT FROM NULL --> f
IS NOT DISTINCT FROM相等,将null视为可比值1 IS NOT DISTINCT FROM NULL --> t
NULL IS NOT DISTINCT FROM NULL --> f
IS NULL1.5 IS NULL --> f
IS NOT NULL‘null’ IS NOT NULL --> t
ISNULL非标准语法
NOTNULL
IS TRUEtrue IS TRUE --> t
NULL::boolean IS TRUE --> f
IS NOT TRUEtrue IS NOT TRUE --> f
NULL::boolean IS NOT TRUE --> t
IS FALSEtrue IS FALSE --> f
NULL::boolean IS FALSE --> f
IS NOT FALSEtrue IS NOT FALSE --> f
NULL::boolean IS NOT FALSE --> t
IS UNKNOWNtrue IS UNKNOWN --> f
NULL::boolean IS UNKNOWN --> t
IS NOT UNKNOWN布尔值是true或falsetrue IS NOT UNKNOWN --> t
NULL::boolean IS NOT UNKNOWN --> f

2.3. 比较函数

常用的比较函数如小表所示:

函数说明示例
num_nonnulls(VARIADIC “any”)返回非null的个数num_nonnulls(1, NULL, 2) ->2
num_nulls(VARIADIC “any”)返回null的个数num_nulls(1, NULL, 2) -> 1

3. 数学函数和运算符

3.1. 数学运算符

常用的数学运算符如下表所示:

符号说明示例
+加号2 + 3 -> 5
++ 3.5 -> 3.5
-减号2 - 3 -> -1
--(-4) -> 4
*2 * 3 -> 6
/5.0 / 2 -> 2.5
%取模5 % 4 -> 1
^立方2^3 -> 8
|/平方根|/ 25.0 -> 5
||/立方根||/ 64.0 -> 4
@绝对值@ -5.0 -> 5.0
&91 & 15 -> 11
|32 | 3 -> 35
#异或17 # 5 -> 20
~取反~1 -> -2
<<按位向左移1 << 4 -> 16
>>按位向右移8 >> 2 -> 2

3.2. 数学函数

常用数学函数如下表所示:

函数名说明示例
abs(n)取绝对值abs(-17.4) -> 17.4
cbrt(d)取立方根cbrt(64.0) -> 4
ceil(n)/ceil(d)向上取整ceil(42.2) -> 43
ceil(-42.8) -> -42
ceiling(n)/ceiling(d)向上取整ceiling(95.3) -> 96
degrees(d)将弧度转为度degrees(0.5) -> 28.64788975654116
div(y, x)y/x的整数商div(9, 4) -> 2
erf(d)erf(1.0) -> 0.8427007929497149
erfc(d)erfc(1.0) -> 0.15729920705028513
exp(n)/exp(d)指数exp(1.0) -> 2.7182818284590452
factorial(n)阶乘factorial(5) -> 120
floor(n)/floor(d)向下取整floor(42.8) -> 42
floor(-42.8) -> -43
gcd(n, n)最大公约数gcd(1071, 462) -> 21
lcm(n, n)最小公倍数lcm(1071, 462) -> 23562
ln(n)/ln(d)自然对数ln(2.0) -> 0.6931471805599453
log(n)/log(d)10为底的对数log(100) -> 2
log10(n)/log10(d)log10(1000) -> 3
log(b,x)以b为底的x对数log(2.0, 64.0) -> 6.000
min_scale(n)最小刻度min_scale(8.4100) -> 2
mod(y, x)y/x的余数mod(9, 4) -> 1
pi()πpi() -> 3.141592653589793
power(a, b)a的b次方power(9, 3) -> 729
radians(d)将度数转为弧度radians(45.0) -> 0.7853981633974483
round(n)/round(d)四舍五入round(42.4) -> 42
round(v, s)四舍五入,保留s位小数round(42.4382, 2) -> 42.44
scale(n)/scale(d)获取小数位数scalse(8.4100) -> 4
sign(n)/sign(d)获取符号(-1, 0, +1)sign(-8.4) -> -1
sqrt(n)/sqrt(d)平方根sqrt(2) -> 1.4142135623730951
trim_scale(n)删除小数后的0trim_scale(8.4100) -> 8.41
trunc(n)/trunc(d)截断为整数trunc(42.8) -> 42
trunc(v, s)截断v到小数点后的s位trunc(42.4382, 2)
width_bucketwidth_bucket(5.35, 0.024, 10.06, 5) -> 3
width_bucketwidth_bucket(now(), array[‘yesterday’, ‘today’, ‘tomorrow’]::timestamptz[]) -> 2

3.3. 随机函数

常用随机函数如下表所示:

函数名说明示例
random()获取0.0到1.0之间的随机值random() -> 0.897124072839091
random_normal(mean, stddev)从给定数的正态分布中返回随机数,mean默认0.0,stddev默认1.0random_normal(0.0, 1.0) -> 0.051285419
setseed(d)给random()和random_normal()设置调用种子,-1.0~1.0setseed(0.12345)

3.4. 三角函数

常用三角函数如下表所示:

函数名说明示例
acos(d)反余弦,返回弧度acos(1) -> 0
acosd(d)反余弦,返回度acosd(0.5) -> 60
asin(d)反正弦,返回弧度asin(1) -> 1.5707963267948966
asind(d)反正弦,返回度asind(0.5) -> 30
atan(d)反正切,返回弧度atan(1) -> 0.7853981633974483
atand(d)反正切,返回度atand(1) -> 45
atan2(y, x)y/x的反正切,返回弧度atan2(1, 0) -> 1.5707963267948966
atan2d(y, x)y/x的反正切,返回度atan2d(1, 0) -> 90
cos(d)余弦,返回弧度cos(0) -> 1
cosd(d)余弦,返回度cosd(60) -> 0.5
cot(d)余切,返回弧度cot(0.5) -> 1.830487721712452
cotd(d)余切,返回度cotd(45) -> 1
sin(d)正弦,返回弧度sin(1) ->
sind(d)正弦,返回度sind(30) -> 0.5
tan(d)正切,返回弧度tan(1) ->
tand(d)正切,返回度tand(45) -> 1

3.5. 双曲线函数

常用双曲线函数如下表所示:

函数名说明示例
sinh(d)双曲正弦sinh(1) -> 1.1752011936438014
cosh(d)双曲余弦cosh(0) -> 1
tanh(d)双曲正切tanh(1) -> 0.7615941559557649
asinh(d)反双曲正弦asinh(1) -> 0.881373587019543
acosh(d)反双曲余弦acosh(1) -> 0
atanh(d)反双曲正切atanh(0.5) -> .5493061443340548

4. 字符串函数和运算符

常用字符串函数如下表所示:

名称说明示例
||拼接
btrim(s, c)移除指定字符cbtrim(‘xyxtrimyyx’, ‘xy’) -> trim
IS [NOT] [form] NORMALIZED检查字符串是否为指定的Unicode形式,默认NFC,还有NFD、NFKC、NFKDU& ‘\0061\0308bc’ IS NFD NORMALIZED -> t
bit_length(text)返回字符串位数bit_length(‘jose’) -> 32
char_length(text)返回字符串字符数char_length(‘jose’) -> 4
lower(text)转小写lower(‘TOM’) -> tom
lpad(s, length, [fill text])填充指定字符lpad(‘hi’, 5, ‘xy’) -> xyxhi
ltrim(str, [char])移除指定字符ltrim(‘zzzytest’, ‘xyz’) -> test
normalize(t, [form])normalize(U& ‘\0061\0308bc’, NFC) -> U& ‘\00E4bc’
octet_length(t)octet_length(‘jose’) -> 5
octet_length(char)octet_length('abc '::character(4)) -> 4
overlay(str PLACING newStr FROM start [FOR count])从头start开始替换count个字符overlay(‘Txxxxas’ placing ‘hom’ from 2 from 4) -> Thomas
position(substr IN str)position(’ om’ in ‘Thomas’ -> 3)
rpad(str, len, [fill])将fill拼接到str后面rpad(‘hi’, 5, ‘xy’) -> hixyx
rtrim(str, [char])移除含有char的字符rtrim(‘testxxzx’, ‘xyz’) -> test
substring(str [FROM start] [FOR count])从start开始截取count位字符substring(‘Thomas’ from 2 for 3) -> hom
substring(str FROM pattern)substring(‘Thomas’ from ‘…$’) -> mas
substring(str SIMILAR pattern ESCAPE escape)
substring(str FROM pattern FOR escape)
substring(‘Thomas’ similar ‘%#“o_a#”_’ escape ‘#’) -> oma
trim([LEADINGTRAILINGBOTH] [char] FROM str)
trim([LEADINGTRAILINGBOTH] [FROM] str, [char])
upper(text)转大写upper(‘tom’) -> TOM
text ^@ text第一个字符以第二个字符开头时返回true‘alphabet’ ^@ ‘alph’ -> true
concat(val1 “any” [, val2 “any” [, …]])连接不为null的字符concat(‘abcde’, 2, NULL, 22) -> abcde222
concat_ws(sep text, val1 “any” [, val2 “any” [, …]])用指定分隔符连接不为null的字符concat_ws(‘,’, ‘abcde’, 2, NULL, 22) -> abcde, 2, 22
format(formatstr text [, formatarg “any” [, …]])格式化字符串format(‘Hello %s, %1$s’, ‘World’) -> Hello World, World
initcap(text)将单词第一个字母大写,其他小写initcap(‘hi THOMAS’) -> Hi Thomas
left(string text, n integer)返回前n个字符left(‘abcde’, 2) -> ab
length(text)返回字符长度length(‘jose’) -> 4
md5(text)返回md5加密后的值md5(‘abc’) -> 900150983cd24fb0d6963f7d28e17f72
pg_client_encoding()返回当前编码pg_client_encoding() -> UTF8
quote_literal(anyelement)将给定的值转换为文本quote_literal(42.5) -> ‘42.5’
quote_nullable(anyelement)将给定的值转换为文本,如果为Null,返回nullquote_nullable(42.5) -> ‘42.5’
repeat(string text, number integer)重复n次repeat(‘Pg’, 4) -> PgPgPg
replace(string text, from text, to text)将from替换为toreplace(‘abcdefabcdef’, ‘cd’, XX) -> abXXefabXXef
reverse(text)反转reverse(‘abcde’) -> edcba
right(string text, n integer)返回后n个字符right(‘abcde’, 2) -> de
split_part(string text, delimiter text, n integer)split_part(‘abc~@~def~@~ghi’, ‘~@~’, 2) -> def
starts_with(string text, prefix text)判断是否已prefix开头starts_with(‘alphabet’, ‘alph’) -> true
substr(string text, start integer [, count integer])从start开始截取count位字符substr(‘alphabet’, 3) -> phabet
substr(‘alphabet’, 3, 2) -> ph
to_hex(integer)将数字转换为十六进制数to_hex(2147483647) -> 7fffffff

5. 格式化函数

常用的格式化函数如下表所示:

函数描述示例
to_char( timestamp, text)根据给定的格式将时间戳转换为字符串to_char(timestamp ‘2024-05-05 17:31:12.66’, ‘HH12:MI:SS’) -> 05:31:12
to_char(interval, text)根据给定的格式将间隔转换为字符串to_char(interval ‘15h 2m 12s’, ‘HH24:MI:SS’) -> 15:02:12
to_char(numeric, text)根据给定的格式将数字转换为字符串to_char(125, ‘999’) -> 125
to_char(125.8::real, ‘999D9’) -> 125.8
to_char(-125.8, ‘999D99S’) -> 125.80-
to_date(text, text)根据给定的格式将字符串转换为日期to_date(‘05 Dec 2023’, ‘DD Mon YYYY’) -> 2023-12-05
to_number(text, text)根据给定的格式将字符串转换为数字to_number(‘12454.8-’, ‘99G999D9S’) -> -12454.8
to_timestamp(text, text)根据给定的格式将字符串转换为时间戳to_timestamp(‘05 Dec 2023’, ‘DD Mod YYYY’) -> 2023-12-05 00:00:00-05

用于数字格式的模板样式如下表所示:

符号描述
9
0
.
,
PR括号中的负值
S负号
L货币符号
D小数点
G组分隔符
MI小于0时减号
PL大于0时加号
SG加号/减号
RN1~3999之间随机数
TH or th序列号后缀
V
EEEE

6. 日期时间函数和运算符

6.1. 日期时间运算符

常用的日期时间运算符如下表所示:

运算符描述示例
date + integer日期加天数date ‘2024-05-05’ + 7 -> 2024-05-12
date + interval日期加时间间隔date ‘2024-05-05’ + interval ‘1 hour’ -> 2024-05-05 01:00:00
date + time日期加时间date ‘2024-05-05’ + time ‘03:00’ -> 2024-05-05 03:00:00
interval + interval时间间隔相加interval ‘1 day’ + interval ‘1 hour’ -> 1 day 01:00:00
timestamp + interval时间戳加时间间隔timestamp ‘2024-05-05 01:00’ + interval ‘23 hours’ -> 2024-05-06 00:00:00
time + interval时间加时间间隔time ‘01:00’ + interval + ‘3 hours’ -> 04:00:00
- interval- interval ‘23 hours’ -> -23:00:00
date - date日期相隔天数date ‘2024-05-05’ - date ‘2024-05-02’ -> 3
date - integern天前date ‘2024-05-05’ - 3 -> 2024-05-02
date - interval日期减时间间隔date ‘2024-05-05’ - interval ‘1 hour’ -> 2024-05-04 23:00:00
time - time相隔多长时间time ‘05:00’ - time ‘03:00’ -> 02:00:00
time - interval时间减时间间隔time ‘05:00’ - interval ‘2 hours’ -> 03:00:00
timestamp - interval时间戳减时间间隔timestamp ‘2024-05-05 23:00’ - interval ‘23 hours’ -> 2024-05-05 00:00:00
interval - interval时间间隔相减interval ‘1 day’ - interval ‘1 hour’ -> 1day -01:00:00
interval * double precision时间间隔乘以小数interval ‘1 second’ * 900 -> 00:15:00
interval ‘1 day’ * 21 -> 21 days
interval ‘1 hour’ * 3.5 -> 03:30:00
interval / double precision时间间隔除以小数interval ‘1 hour’ / 1.5 -> 00:40:00

6.2. 日期时间函数

常用的日期时间函数如下表所示:

函数描述示例
age(timestamp, timestamp)age(timestamp ‘2024-05-05’, timestamp ‘2010-03-15’) -> 14 years 1 mon 21 days
age(timestamp)当前日期相减age(timestamp ‘2010-03-15’) -> 14 years 1 mon 24 days
clock_timestamp()当前日期时间带时区clock_timestamp() -> 2024-05-08 11:45:59.727 +0800
current_date当前日期current_date -> 2024-05-05
current_time当前时间current_time -> 14:39:53.662522+08
current_time(integer)当前时间带时区14:39:53.66+08
current_timestamp当前日期时间带时区current_timestamp(0) -> 2024-05-05 14:39:53+08
date_add(timestamp with time zone, interval [, text])日期相加date_add(‘2024-05-05 00:00:00+08’ :: timestamptz, ‘1 day’ :: interval, ‘Asia/Shanghai’) -> 2024-05-06 00:00:00+08
date_bin(interval, timestamp, timestamp)date_bin(‘15 minutes’, timestamp ‘2024-05-05 09:40:00’, timestamp ‘2024-05-05 09:05:00’) -> 2024-05-05 09:35:00.000
date_part(text, timestamp)获取小时数date_part(‘hour’, timestamp ‘2024-05-05 09:40:00’) -> 09
date_part(text, interval)date_part(‘month’, interval ‘2 years 3 months’) -> 3
date_subtract(timestamp with time zone, intervl [, text])日期相减date_subtract(‘2024-05-05 00:00:00+08’::timestamptz, ‘1 day’::interval, ‘Asia/Shanghai’) ->
date_trunc(text, timestamp)只获取日期和小时date_trunc(‘hour’, timestamp ‘2024-05-05 09:40:00’) -> 2024-05-05 09:00:00
date_trunc(text, timestamp with time zone, text)获取指定时区的日期date_trunc(‘day’, timestamptz ‘2024-05-05 09:40:00’, ‘Asia/Shanghai’) ->
date_trunc(text, interval)date_trunc(‘hour’, interval ‘2 days 3 hours 40 minutes’) -> 2 days 03:00:00
localtime获取当前时间localtime -> 09:40:53.662522
localtime(integer)获取当前时间localtime(0) -> 09:40:53
localtimestamp获取当前日期时间localtimestamp -> 2024-05-05 09:40:00.662522
localtimestamp(integer)获取当前日期时间localtimestamp(2) -> 2024-05-05 09:40:00.66
make_date(year int, month int, day int)make_date(2024, 05, 05) -> 2024-05-05
make_interval([years int [, months int [, weeks int [, days int [, hours int [, mins int [, secs double precision ]]]]]]])make_interval(days => 10) -> 10 days
make_time(hour int, min int, sec double precision)make_time(8, 15, 23.5) -> 08:15:23.5
make_timestamp(year int, month int, day int, hour int, min int, sec double precision)make_timestamp(2024, 05, 05, 8, 15, 23.5) -> 2024-05-05 08:15:23.5
make_timestamptz(year int, month int, day int, hour int, min int, sec double precision [, timezone text])make_timestamptz(2024, 5, 5, 8, 15, 23.5) -> 2024-05-05 08:15:23.5+08
make_timestamptz(2024, 5, 5, 8, 15, 23.5, ‘’) -> 2024-05-05 08:15:23.5+08
now()获取当前日期时间now() -> 2024-05-05 09:40:00.662522+08
statement_timestamp()当前日期时间statement_timestamp() -> 2024-05-05 14:04:32.735 +0800
timeofday()当前日期时间timeofday() ->
transaction_timestamp()当前日期时间transaction_timestamp() ->
to_timestamp(double precision)转换时间戳to_timestamp(23343) ->

7. 开窗函数

常用的开窗函数如下表所示:

函数描述
row_number()返回当前行在其分区内的编号,从1开始
rank()返回当前行的列组
dense_rank()返回当前行的排名
percent_rank返回当前行的相对排名,即(排名-1)/(总分区行数-1)
cume_dist()返回累积分布,即(当前行前面或与当前行对等的分区行数)/(分区行总数)
ntile(num integer)返回一个从1到参数值的整数
lag(value anycompatible [, offset integer [, default anycompatible]])
lead(value anycompatible [, offset integer [, default anycompatible]])
first_value(value anyelement)返回在窗口框架的第一行计算的值
last_value(value anyelement)返回在窗口框架的最后行计算的值
nth_value(value anyelement, n integer)返回在窗口框架的第n行计算的值

相关文章:

PostgreSQL函数和运算符

PostgreSQL为内置的数据类型提供了大量的函数和运算符&#xff0c;用户也可以定义自己的函数和运算符&#xff0c;使用psql命令\df和\do可以列出所有可用的函数和运算符 1. 逻辑运算符 常用的逻辑运算符有AND、OR、NOT&#xff0c;逻辑系统有三个值true、fase和null&#xff…...

使用网络工具监控网络性能

网络工具和实用程序有助于有效地检测网络问题&#xff0c;诊断其原因和位置&#xff0c;以及缓解和解决问题&#xff0c;这有助于确保网络环境的稳定性&#xff0c;使用户免受设备连接问题带来的麻烦。 网络工具已经成为每个网络管理员用于有效诊断和处理网络问题的解决方案中…...

Gradle基础笔记

配置镜像 修改 gradle>wrapper>gradle-wrapper.properties distributionUrlhttps://mirrors.aliyun.com/macports/distfiles/gradle/gradle-8.6-all.zip 配置父项目 使用 subprojects 编码问题处理 [compileJava, compileTestJava, javadoc].options.encoding ‘UTF-…...

QT+网络调试助手+TCP客户端

一、网络调试助手UI界面 编程主要思路&#xff1a; 首先将水平的控件 水平布局 &#xff0c;然后相对垂直的控件 垂直布局 &#xff0c;哪怕是底下的groupBox也需要和里面的内容 水平布局&#xff0c;然后最后框选全部 栅格布局。如果需要界面自适应窗口大小&#xff0c…...

数据库调优-SQL语句优化

2. SQL语句优化 sql 复制代码 # 请问这两条SQL语句有什么区别呢&#xff1f;你来猜一猜那条SQL语句执行查询效果更好&#xff01; select id from sys_goods where goods_name华为 HUAWEI 麦芒7 魅海蓝 6G64G 全网通; ​ select id from sys_goods where goods_id14967325985…...

h函数 render函数 JSX基本用法

1.1认识h函数&#xff08;hyperscript工具 基于JavaScript编写模板的工具&#xff09; Vue推荐在绝大多数情况下使用模板来创建你的HTML&#xff0c;然后一些特殊的场景&#xff0c;需要JavaSript的完全编程能力&#xff0c;可以使用渲染函数&#xff0c;它比模板更接近编译器&…...

购物车操作

添加购物车&#xff1a; 需求分析和接口设计&#xff1a; 接口设计&#xff1a; 请求方式&#xff1a;POST 请求路径&#xff1a;/user/shoppingCart/add请求参数&#xff1a;套餐id、菜品id、口味返回结果&#xff1a;code、data、msg 数据库设计&#xff1a; 这上面出现了…...

华为手机 鸿蒙系统-android studio识别调试设备,开启adb调试权限

1.进入设置-关于手机-版本号&#xff0c;连续点击7次 认证&#xff1a;有锁屏密码需要输入密码&#xff0c; 开启开发者配置功能ok 进入开发者配置界面 打开调试功能 重新在androd studio查看可运行running devices显示了&#xff0c; 不行的话&#xff0c;重启一下android …...

计算机网络——Dijkstra路由算法

实验目的 实现基于 Dijkstra 算法的路由软件 实验内容 网络拓扑如图所示 实验过程 先编写开辟应该图的空间&#xff0c;然后给点映射数字&#xff0c;构建图。程序获取用户输入的学号&#xff0c;构建图中边的权值。接下来程序从用户输入获取最短路径的搜索起点&#xff0…...

AI智能化逐渐趋于成熟后,预测今后最吃香的开发职业

AI智能化正在成熟的路途中&#xff0c;这中间会有波折&#xff0c;但终有一天会来的&#xff0c;我相信等到了这一天&#xff0c;我们的开发效率和代码质量&#xff0c;将会大大不同&#xff0c;而我们的团队与个人&#xff0c;也会面临着很棒的体验。 那么在AI智能化真正趋于成…...

Acwing2024蓝桥杯BFS

AcWing 1355. 母亲的牛奶 bfs: #include<iostream> #include<queue> using namespace std; const int N21; int A,B,C; bool flag[N][N][N]; struct node{int a,b,c; }; queue<node>q; void check(int a,int b,int c){if(!flag[a][b][c]){q.push({a,b,c})…...

vue打包报错:CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory

前言&#xff1a; vue项目&#xff0c;打包报错&#xff1a;CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 报错现象&#xff1a; 报错原因&#xff1a; 这个错误是由Node.js在尝试分配内存时因为系统的可用内存不足而发生的。"JavaScript heap…...

计算机组成原理网课笔记

无符号整数的表示与运算 带符号整数的表示与运算 原反补码的特性对比 移码 定点小数...

Python学习第四部分 函数式编程

文章目录 高阶函数lambda 表达式和匿名函数偏函数闭包map函数reduce函数filter 函数sorted函数 函数式编程主要学习&#xff1a;高阶函数、闭包closure、匿名函数、偏函数&#xff0c;map函数、reduce函数、filter函数、sorted函数 函数式编程是个很古老的概念&#xff0c;最古…...

数据结构-二叉树-AVL树(平衡二叉树)

红黑树是平衡二叉树的一个变种。 一、 产生平衡二叉树的原因。 二叉搜索树的问题在于极端场景下退化为类似链表的结构&#xff0c;所以搜索的时间复杂度就变成了O(N)。为了保证二叉树不退化为链表&#xff0c;我们必须保证二叉树的的平衡性。 二叉平衡搜索树就是解决上面的问…...

【Qt问题】windeployqt如何提取Qt依赖库

往期回顾 【Qt问题】Qt Creator 如何链接第三方库-CSDN博客 【Qt问题】Qt 如何带参数启动外部进程-CSDN博客 【Qt问题】VS2019 Qt win32项目如何添加x64编译方式-CSDN博客 【Qt问题】windeployqt如何提取Qt依赖库 考虑这个问题主要是&#xff1a;当我们的程序运行好之后&#…...

VS2019下使用MFC完成科技项目管理系统

背景&#xff1a; &#xff08;一&#xff09;实验目的 通过该实验&#xff0c;使学生掌握windows程序设计的基本方法。了解科技项目组织管理的主要内容和管理方面的基本常识&#xff0c;熟练应用数据库知识&#xff0c;通过处理过程对计算机软件系统工作原理的进一步理解&…...

【Android】Kotlin学习之数据容器(数组for循环遍历)

数组遍历 1. for ( item in arr){…} 2. for ( i in arr.indeces ) {…} (遍历下标) 3. for ((index, item) in arr.withInfex()) {…} (遍历下标和元素) 4. arr.forEach {} ( 遍历元素 ) 5. arr.forEachIndexed{index, item -> …}...

JavaWeb_请求响应_简单参数实体参数

一、SpringBoot方式接收携带简单参数的请求 简单参数&#xff1a;参数名与形参变量名相同&#xff0c;定义形参即可接收参数。并且在接收过程中&#xff0c;会进行自动的类型转换。 启动应用程序后&#xff0c;在postman中进行测试&#xff1a; 请求成功&#xff0c;响应回了O…...

windows端口复用

1. 概述 使用 HTTP.sys 中的 Net.tcp Port Sharing 服务&#xff0c;配合 WinRM 实现端口复用。 优点&#xff1a; HTTP.sys 为 windows 原生机制&#xff0c; WinRM 为 windows 自带功能&#xff0c;动作较小&#xff0c;不易触发主 动防御。 需要管理员权限。 2. 原理 (…...

conda相比python好处

Conda 作为 Python 的环境和包管理工具&#xff0c;相比原生 Python 生态&#xff08;如 pip 虚拟环境&#xff09;有许多独特优势&#xff0c;尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处&#xff1a; 一、一站式环境管理&#xff1a…...

智慧医疗能源事业线深度画像分析(上)

引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

K8S认证|CKS题库+答案| 11. AppArmor

目录 11. AppArmor 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作&#xff1a; 1&#xff09;、切换集群 2&#xff09;、切换节点 3&#xff09;、切换到 apparmor 的目录 4&#xff09;、执行 apparmor 策略模块 5&#xff09;、修改 pod 文件 6&#xff09;、…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

postgresql|数据库|只读用户的创建和删除(备忘)

CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...

【2025年】解决Burpsuite抓不到https包的问题

环境&#xff1a;windows11 burpsuite:2025.5 在抓取https网站时&#xff0c;burpsuite抓取不到https数据包&#xff0c;只显示&#xff1a; 解决该问题只需如下三个步骤&#xff1a; 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一)

宇树机器人多姿态起立控制强化学习框架论文解析 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架&#xff08;一&#xff09; 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化…...

JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案

JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停​​ 1. ​​安全点(Safepoint)阻塞​​ ​​现象​​:JVM暂停但无GC日志,日志显示No GCs detected。​​原因​​:JVM等待所有线程进入安全点(如…...