c03-基础定义,技巧,打印乘法表

本文介绍了C++编程中的一些实用技巧,包括按位异或的应用、不使用中间变量进行变量交换、计算整数中1的个数的方法、运算符优先级规则、变量初始化与赋值的区别、使用time(0)获取时间戳、处理cout缓冲区问题、循环打印九九乘法表、随机数生成及sleep函数用法,并对比了C与C++中null的不同。

1.^按位异或,相同为0相异为1

2.不使用中间变量交换变量的值:a=a^b; b=a^b; a=a^b;

3.计算数中1的个数:

 

int fun(const int i)

{

int count = 0;

while(i>0)

{

i&=(i-1);

++count;

}

return count;

}

4.运算符号优先级:

前三:括号,成员,单目(需要变量为几的运算符为几目运算符)

后三:三目,赋值,逗号

5.变量初始化:int a = 5; 赋值:int b; b = 5;

6.左值:变量或结果是变量的式子,等号左边

7.time(0)函数结果为:1970.1.1 00:00:00~现在的秒数,头文件<ctime>

8.cout缓冲区的问题和cerr

cout有缓冲区可以cout.flush()或cout<<flush清空缓冲区强制输出;,cerr报错使用要立即输出

9.for(;;)比while(1)效率高一些,for不用比较,while需比较

10.一层循环打出99表

for(int i = 1, j = 1; i <= 9 && j <= 9; ++i)

{

cout<<i<<"*"<<j<<"="<<i*j;

if (i < j)

cout<<",";

else

{

cout<<'\n';

++j;

i = 0;

}

}

11.srand(time(0)); rand(); 头文件<cstdlib>

12.linux中sleep(i)的i为秒,头文件<unistd.h>

13.c和c++中null的区别:

null为空字符('\0'); c中定义NULL为(void*)0;可隐式转换为其他类型的指针; c++中定义NULL为0;C++中void*无法自由隐式转换为其它类型的指针,而字面量0可以隐式转换为指针类型;

你希望根据 `file_id` 字段中某个部分(如 `-2509-` 或 `-2508-`)为每个相同前缀的值生成**唯一递增的流水号**,例如: - 原始值:`C03-PCB-TS-2509-51`、`C03-PCB-TS-2509-51` - 期望值:`C03-PCB-TS-2509-52`、`C03-PCB-TS-2509-53` --- ## ✅ 实现思路 1. 使用 SQL 提取 `file_id` 中的“前缀”部分(即 `-2509-` 前的部分); 2. 使用 `ROW_NUMBER()` 按该前缀进行编号; 3. 使用 `UPDATE` 更新 `file_id` 字段为新生成的唯一值。 --- ## ✅ 示例 SQL(以 PostgreSQL 为例) ### 1. 查看当前数据结构和生成新值(测试阶段) ```sql SELECT file_id, -- 提取前面的固定部分,如 C03-PCB-TS-2509- split_part(file_id, '-', 1) || '-' || split_part(file_id, '-', 2) || '-' || split_part(file_id, '-', 3) || '-' || split_part(file_id, '-', 4) || '-' AS prefix, -- 使用 ROW_NUMBER() 为每个前缀生成唯一编号 ROW_NUMBER() OVER (PARTITION BY split_part(file_id, '-', 1) || '-' || split_part(file_id, '-', 2) || '-' || split_part(file_id, '-', 3) || '-' || split_part(file_id, '-', 4) ORDER BY file_id ) AS seq FROM testdup.dynamic_general_ledger; ``` --- ### 2. 更新 `file_id` 字段(正式操作) ```sql WITH numbered AS ( SELECT id, file_id, split_part(file_id, '-', 1) || '-' || split_part(file_id, '-', 2) || '-' || split_part(file_id, '-', 3) || '-' || split_part(file_id, '-', 4) AS prefix, ROW_NUMBER() OVER (PARTITION BY split_part(file_id, '-', 1) || '-' || split_part(file_id, '-', 2) || '-' || split_part(file_id, '-', 3) || '-' || split_part(file_id, '-', 4) ORDER BY file_id ) AS seq FROM testdup.dynamic_general_ledger ) UPDATE testdup.dynamic_general_ledger AS t SET file_id = n.prefix || (n.seq + 51) -- 从 52 开始 FROM numbered AS n WHERE t.id = n.id; ``` > ✅ 解释: > - `split_part(..., '-', 4)` 提取前4段,作为分组依据; > - `ROW_NUMBER()` 为每个组生成唯一编号; > - `+ 51` 表示从 `52` 开始生成流水号; > - 使用 `id` 做关联更新,确保准确。 --- ## ✅ 示例输出 | 原始 file_id | 新 file_id | |--------------|-------------| | C03-PCB-TS-2509-51 | C03-PCB-TS-2509-52 | | C03-PCB-TS-2509-51 | C03-PCB-TS-2509-53 | | C03-PCB-TS-2508-51 | C03-PCB-TS-2508-52 | | C03-PCB-TS-2508-51 | C03-PCB-TS-2508-53 | --- ## ✅ 注意事项 - **备份数据**:更新前建议先备份表; - **字段长度**:确保 `file_id` 字段长度足够存储新值; - **索引影响**:如果 `file_id` 有索引,更新大量数据可能会影响性能; - **可扩展性**:如果你的 `file_id` 结构更复杂,可以使用正则提取(如 `regexp_match`)。 --- ## ✅ 扩展:使用正则提取前缀(更灵活) ```sql SELECT file_id, (regexp_match(file_id, '^(.*?-\d+)-\d+$'))[1] AS prefix, ROW_NUMBER() OVER (PARTITION BY (regexp_match(file_id, '^(.*?-\d+)-\d+$'))[1] ORDER BY file_id) AS seq FROM testdup.dynamic_general_ledger; ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值