select b_c_id, b_type into r_id, r_type from bank_card where b_number = dest_card_id; if s_id != applicant_id or r_id != receiver_id or (s_type = "信用卡" and r_type = "储蓄卡") or (s_type = "储蓄卡" and s_b < amount) then set return_code = 0; leave pro; end if; if s_type = "信用卡" then set amount = -amount; end if; if r_type = "信用卡" then set rcv_amount = -rcv_amount; end if;
时间: 2024-04-23 19:25:33 浏览: 80
这是一个 MySQL 存储过程中的一段代码。该代码用于根据条件判断是否可以进行银行转账,并设置相关变量。其中,dest_card_id 是目标银行卡号,s_id、r_id 分别是源银行卡和目标银行卡的持有人 ID,s_type、r_type 分别是源银行卡和目标银行卡的类型(储蓄卡或信用卡),s_b 表示源银行卡的余额,amount 表示转账金额,rcv_amount 表示目标银行卡的余额。
该代码首先从 bank_card 表中查询出目标银行卡的持有人 ID 和类型,并将结果赋值给变量 r_id 和 r_type。然后,通过 if 语句判断转账条件是否符合要求。如果源银行卡或目标银行卡的持有人 ID 不等于指定的值,或者源银行卡是信用卡、目标银行卡是储蓄卡且源银行卡余额不足以完成转账,则设置返回码为 0,并退出存储过程。如果源银行卡是信用卡,则将转账金额取相反数,表示从信用卡中扣除金额。如果目标银行卡是信用卡,则将接收金额取相反数,表示向信用卡中添加金额。
相关问题
from pdb import set_trace as st import os import numpy as np import cv2 import argparse parser = argparse.ArgumentParser('create image pairs') parser.add_argument('--fold_A', dest='fold_A', help='input directory for image A', type=str, default='../dataset/50kshoes_edges') parser.add_argument('--fold_B', dest='fold_B', help='input directory for image B', type=str, default='../dataset/50kshoes_jpg') parser.add_argument('--fold_AB', dest='fold_AB', help='output directory', type=str, default='../dataset/test_AB') parser.add_argument('--num_imgs', dest='num_imgs', help='number of images',type=int, default=1000000) parser.add_argument('--use_AB', dest='use_AB', help='if true: (0001_A, 0001_B) to (0001_AB)',action='store_true') args = parser.parse_args() for arg in vars(args): print('[%s] = ' % arg, getattr(args, arg)) splits = os.listdir(args.fold_A) for sp in splits: img_fold_A = os.path.join(args.fold_A, sp) img_fold_B = os.path.join(args.fold_B, sp) img_list = os.listdir(img_fold_A) if args.use_AB: img_list = [img_path for img_path in img_list if '_A.' in img_path] num_imgs = min(args.num_imgs, len(img_list)) print('split = %s, use %d/%d images' % (sp, num_imgs, len(img_list))) img_fold_AB = os.path.join(args.fold_AB, sp) if not os.path.isdir(img_fold_AB): os.makedirs(img_fold_AB) print('split = %s, number of images = %d' % (sp, num_imgs)) for n in range(num_imgs): name_A = img_list[n] path_A = os.path.join(img_fold_A, name_A) if args.use_AB: name_B = name_A.replace('_A.', '_B.') else: name_B = name_A path_B = os.path.join(img_fold_B, name_B) if os.path.isfile(path_A) and os.path.isfile(path_B): name_AB = name_A if args.use_AB: name_AB = name_AB.replace('_A.', '.') # remove _A path_AB = os.path.join(img_fold_AB, name_AB) im_A = cv2.imread(path_A, cv2.IMREAD_COLOR) im_B = cv2.imread(path_B, cv2.IMREAD_COLOR) im_AB = np.concatenate([im_A, im_B], 1) cv2.imwrite(path_AB, im_AB),解释上述代码,并告诉我怎么设置文件夹格式
这段代码用于创建图像对,将两个文件夹中的图像拼接在一起,并将结果保存在一个新的文件夹中。下面是代码的简要解释:
1. 引入必要的库:pdb、os、numpy、cv2和argparse。
2. 使用argparse来解析命令行参数,包括输入目录和输出目录等。
3. 遍历输入目录中的所有文件夹,并获取每个文件夹中的图像列表。
4. 根据命令行参数,选择要使用的图像对(如果--use_AB参数为true,则仅使用"_A"结尾的图像作为输入A,使用相应的"_B"图像作为输入B)。
5. 将输入A和输入B图像拼接在一起,并将结果保存在输出目录中。
6. 最后,打印出图像对的数量和输出目录等信息。
文件夹格式应该是这样的:
- dataset
- 50kshoes_edges
- split1
- 0001_A.png
- 0002_A.png
- ...
- split2
- 0001_A.png
- 0002_A.png
- ...
- ...
- 50kshoes_jpg
- split1
- 0001_B.jpg
- 0002_B.jpg
- ...
- split2
- 0001_B.jpg
- 0002_B.jpg
- ...
- ...
- test_AB
- split1
- 0001.png
- 0002.png
- ...
- split2
- 0001.png
- 0002.png
- ...
- ...
select flt_no as fltNo, flt_date as fltDate, create_pnr_office_id as createPnrOfficeId, pnr_create_date as pnrCreateDate, gds, bkd_cnt as bkdCnt, tkt_cnt as tktCnt, rfd_cnt as rfdCnt, void_cnt as voidCnt, issue_ratio as issueRatio, SPLIT_PART(segment, '-', 1) as origin, SPLIT_PART(segment, '-', 2) as dest from inter.mid_pnr_waste_seats where flt_date in('2023-07-22') and ( exists (select * from inter.mid_bas_rm_dist where inter.mid_bas_rm_dist.valid_start_date<= flt_date and inter.mid_bas_rm_dist.valid_end_date>= flt_date and inter.mid_bas_rm_dist.dep_code=SPLIT_PART(segment, '-', 1) and inter.mid_bas_rm_dist.arr_code= SPLIT_PART(segment, '-', 2) and inter.mid_bas_rm_dist.rm_dist in ('欧洲区' , '测试区' , 'test区1' , '亚洲区' , '俄中东区'))) and SPLIT_PART(segment, '-', 1) in (select dep_code from inter.mid_bas_rm_dist where inter.mid_bas_rm_dist.valid_start_date<= flt_date and inter.mid_bas_rm_dist.valid_end_date>= flt_date and inter.mid_bas_rm_dist.rm_dist in ('欧洲区' , '测试区' , 'test区1' , '亚洲区' , '俄中东区'))and SPLIT_PART(segment, '-', 2) in (select arr_code from inter.mid_bas_rm_dist where inter.mid_bas_rm_dist.valid_start_date<= flt_date and inter.mid_bas_rm_dist.valid_end_date>= flt_date and inter.mid_bas_rm_dist.rm_dist in ('欧洲区' , '测试区' , 'test区1' , '亚洲区' , '俄中东区'))
这是一个SQL查询语句,用于从表inter.mid_pnr_waste_seats中选择特定条件的数据。查询的结果包括flt_no作为fltNo,flt_date作为fltDate,create_pnr_office_id作为createPnrOfficeId,pnr_create_date作为pnrCreateDate,gds,bkd_cnt作为bkdCnt,tkt_cnt作为tktCnt,rfd_cnt作为rfdCnt,void_cnt作为voidCnt,issue_ratio作为issueRatio,以及从segment字段中使用SPLIT_PART函数提取出来的origin和dest两个字段。
查询条件包括flt_date等于'2023-07-22',以及一个子查询,其中检查了inter.mid_bas_rm_dist表中的数据。子查询中的条件是valid_start_date小于等于flt_date,valid_end_date大于等于flt_date,dep_code等于segment字段中使用SPLIT_PART函数提取出来的第一部分,arr_code等于segment字段中使用SPLIT_PART函数提取出来的第二部分,rm_dist在('欧洲区' , '测试区' , 'test区1' , '亚洲区' , '俄中东区')中。
此外,还有两个条件,分别检查了dep_code和arr_code是否存在于inter.mid_bas_rm_dist表中,并且满足相同的条件。
请注意,这只是一个简单的解释,实际上可能还有其他细节需要考虑。
阅读全文