EDP_EDP_EXTERNAL_PLANT_REPORT_U_$RUN_DATE.dat与 SELECT BYTES FROM USER_SEGMENTS WHERE SEGMENT_NAME = 'table_name_bad';与 SELECT NUM_ROWS FROM USER_TABLES WHERE TABLE_NAME = 'table_name_bad'; 及$RUN_DATE 如何将上面语句结果集拼接为复合的SELECT语句并将结果用空格隔开?
时间: 2023-08-03 18:05:31 浏览: 87
以下是将上述语句结果集拼接为复合的SELECT语句并将结果用空格隔开的示例代码:
```
SELECT
EDP_EDP_EXTERNAL_PLANT_REPORT_U_$RUN_DATE.dat || ' ' || BYTES || ' ' || NUM_ROWS AS result
FROM
(SELECT
(SELECT COUNT(*) FROM USER_SEGMENTS WHERE SEGMENT_NAME = 'table_name_bad') AS BYTES,
(SELECT NUM_ROWS FROM USER_TABLES WHERE TABLE_NAME = 'table_name_bad') AS NUM_ROWS
FROM
dual)
CROSS JOIN
(SELECT TO_CHAR(SYSDATE, 'YYYYMMDD') AS $RUN_DATE FROM dual);
```
其中,EDP_EDP_EXTERNAL_PLANT_REPORT_U_$RUN_DATE.dat、table_name_bad和$RUN_DATE需要替换为实际的值。
相关问题
def gen_conn_msg(pid=None,auth_info=None): msg_type=b'\x10' proto_desc=b'\x00\x03EDP' proto_ver=b'\x01' keepalive=struct.pack('!H',300) if pid and auth_info: conn_flag=b'\xc0' pid_len=struct.pack('!H',len(pid)) pid=pid.encode('utf-8') auth_info_len=struct.pack('!H',len(auth_info)) auth_info=auth_info.encode('utf-8') device=b'\x00\x00' auth=pid_len+pid+auth_info_len+auth_info else: print('CONN_REQ:params error,request params are not given!') raise Exception rest=proto_desc+proto_ver+conn_flag+keepalive+device+auth body_len=bytes([len(rest)]) conn_msg=msg_type+body_len+rest return conn_msg def recv_data_parser(recv_data): if not recv_data: sys.exit() elif recv_data[0]==0x90: msg_id=struct.unpack('!H',recv_data[3:5])[0] if recv_data[-1]==0: res=True else: res=False return msg_id,res elif recv_data[0]==0x20: pass elif recv_data[0]==0xA0: body_len,length_len=calc_body_len(recv_data) mark=length_len+1 cmdid_len=recv_data[mark:mark+2] mark+=2 cmdid_len=struct.unpack('!H',cmdid_len)[0] cmd_id=recv_data[mark:mark+cmdid_len] mark+=cmdid_len cmdbody_len=recv_data[mark:mark+4] mark += 4 cmd_body=recv_data[mark:] return cmd_id,cmd_body elif recv_data[0]==0xD0: pass elif recv_data[0]==0x40: return False,False def calc_body_len(r_msg): res=[] for x in range(4): if r_msg[x+1]>128: res.append(r_msg[x+1]-128) else: res.append(r_msg[x + 1]) if x==3 and r_msg[x+1]>128: print('Error:Wrong body length!') return body_len=0 for x in range(len(res)): body_len+=res[x]*128**x return body_len,len(res)解释上述代码
这段代码是一个基于EDP协议的消息解析和生成器。
gen_conn_msg()函数用于生成连接请求消息,可以传递pid和auth_info参数以进行身份验证。如果参数不正确,则会引发异常。
recv_data_parser()函数用于解析接收到的消息。它根据消息类型进行不同的处理。对于0x90和0x40类型的消息,它只返回一个布尔值。对于0xA0类型的消息,它返回cmd_id和cmd_body。对于其他类型的消息,它暂时不进行处理。
calc_body_len()函数用于计算消息体的长度。它根据EDP协议的规则,将前四个字节进行解析,并计算出消息体的长度。
该代码实现了一个基本的EDP协议的消息解析和生成器,可以用于与EDP协议兼容的设备进行通信。
阅读全文