INSERT_RSLT=`sqlplus -S $DWUSR/$DWPWD@$DWIP:$DWPORT/$DWDNS <<eof var V_OUT_RETCODE varchar2(3000); call P_ADD_TABLE_PART('ALL','$p_data_dt',:V_OUT_RETCODE); select :V_OUT_RETCODE from dual; exit; eof` echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1" if [ $? -ne 0 ];then echo `date +"%Y-%m-%d %T"` "分区存储过程运行成功">>$SYSDIR/syslog/sys$p_data_dt.log echo `date +"%Y-%m-%d %T"` "P_ADD_TABLE_PART success" else echo `date +"%Y-%m-%d %T"` "分区存储过程运行错误">>$SYSDIR/syslog/sys$p_data_dt.log echo `date +"%Y-%m-%d %T"` "P_ADD_TABLE_PART error" java -jar $HOME/fileCheckEmail.jar $p_data_dt 103 exit 1 fi
时间: 2024-04-20 17:26:34 浏览: 197
这段代码是一个Shell脚本,它执行了一个SQL脚本,并根据执行结果输出不同的信息。首先,它使用`sqlplus`命令连接到数据库,并执行一个存储过程`P_ADD_TABLE_PART`,并将返回的结果赋值给变量`V_OUT_RETCODE`。然后,它检查返回结果中是否包含错误信息,如果没有错误信息,则输出成功信息并记录日志;如果有错误信息,则输出错误信息并记录日志,然后执行一个Java程序`fileCheckEmail.jar`并传递参数`$p_data_dt`和`103`,最后退出脚本。
相关问题
echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1" echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1" echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1" echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1" echo $INSERT_RSLT | grep -E "ERROR|error|SP2-0306|ORA-|-1
这段代码是在连续执行5次`grep`命令,并将变量`$INSERT_RSLT`作为输入进行匹配。它使用正则表达式`"ERROR|error|SP2-0306|ORA-|-1"`来匹配字符串中是否包含"ERROR"、"error"、"SP2-0306"、"ORA-"或"-1"这些关键词。每次执行`grep`命令后,将输出结果打印到终端。这样做可能是为了多次检查返回结果中是否存在特定的错误信息。
BME280_RETURN_FUNCTION_TYPE bme280_init(struct bme280_t *bme280) { /* used to return the communication result*/ BME280_RETURN_FUNCTION_TYPE com_rslt = ERROR; u8 v_data_u8 = BME280_INIT_VALUE; u8 v_chip_id_read_count = BME280_CHIP_ID_READ_COUNT; /* assign BME280 ptr */ p_bme280 = bme280; while (v_chip_id_read_count > 0) { /* read Chip Id */ com_rslt = p_bme280->BME280_BUS_READ_FUNC(p_bme280->dev_addr, BME280_CHIP_ID_REG, &v_data_u8, BME280_GEN_READ_WRITE_DATA_LENGTH); /* Check for the correct chip id */ if (v_data_u8 == BME280_CHIP_ID) break; v_chip_id_read_count--; /* Delay added concerning the low speed of power up system to facilitate the proper reading of the chip ID */ p_bme280->delay_msec(BME280_REGISTER_READ_DELAY); } /*assign chip ID to the global structure*/ p_bme280->chip_id = v_data_u8; /*com_rslt status of chip ID read*/ com_rslt = (v_chip_id_read_count == BME280_INIT_VALUE) ? BME280_CHIP_ID_READ_FAIL : BME280_CHIP_ID_READ_SUCCESS; if (com_rslt == BME280_CHIP_ID_READ_SUCCESS) { /* readout bme280 calibparam structure */ com_rslt += bme280_get_calib_param(); } return com_rslt; }
这段代码是用于BME280传感器初始化的函数。它的作用是读取传感器的芯片ID,并验证是否与预期的ID匹配,然后读取校准参数。
这里是代码的解析:
```c
BME280_RETURN_FUNCTION_TYPE bme280_init(struct bme280_t *bme280)
{
BME280_RETURN_FUNCTION_TYPE com_rslt = ERROR; // 用于返回通信结果的变量
u8 v_data_u8 = BME280_INIT_VALUE; // 初始化为0的变量
u8 v_chip_id_read_count = BME280_CHIP_ID_READ_COUNT; // 芯片ID读取计数器
p_bme280 = bme280; // 将传入的bme280指针赋值给全局变量p_bme280
while (v_chip_id_read_count > 0) {
com_rslt = p_bme280->BME280_BUS_READ_FUNC(p_bme280->dev_addr, BME280_CHIP_ID_REG, &v_data_u8, BME280_GEN_READ_WRITE_DATA_LENGTH);
// 通过总线读取芯片ID寄存器的值
if (v_data_u8 == BME280_CHIP_ID)
break; // 检查芯片ID是否匹配,如果匹配则跳出循环
v_chip_id_read_count--;
p_bme280->delay_msec(BME280_REGISTER_READ_DELAY); // 延时一段时间再尝试读取芯片ID
}
p_bme280->chip_id = v_data_u8; // 将读取到的芯片ID赋值给全局结构体的chip_id字段
com_rslt = (v_chip_id_read_count == BME280_INIT_VALUE) ? BME280_CHIP_ID_READ_FAIL : BME280_CHIP_ID_READ_SUCCESS;
// 根据芯片ID读取结果更新com_rslt的值
if (com_rslt == BME280_CHIP_ID_READ_SUCCESS) {
com_rslt += bme280_get_calib_param(); // 读取BME280的校准参数
}
return com_rslt; // 返回通信结果
}
```
这段代码使用了一些宏定义和结构体,其中BME280_RETURN_FUNCTION_TYPE是一个自定义的返回函数类型,u8是一个8位无符号整数类型。它还使用了全局变量p_bme280,这个变量在其他地方应该有定义和初始化。
该函数首先通过总线读取芯片ID寄存器的值,然后检查读取到的值是否与预期的芯片ID匹配。如果匹配,则跳出循环,将芯片ID赋值给全局结构体的chip_id字段。如果读取芯片ID失败(读取计数器减为0),则返回失败状态。如果读取芯片ID成功,则调用bme280_get_calib_param()函数读取BME280的校准参数,并返回通信结果。
这段代码的目的是在初始化BME280传感器时,确保与传感器建立正确的通信,并读取必要的校准参数,以便后续的数据读取和计算。
阅读全文