修改完整版的sql存储(积分兑换脚本),改写出可执行的shell脚本 message "DATEFORMAT"("NOW"(),'YYYYMMDD HH:NN:SS') || '更新号码、局向标签:' || @@ROWCOUNT || ' 条' type info to client;
时间: 2023-08-21 16:27:48 浏览: 120
您好,根据您提供的 SQL 语句,我为您编写了一个可执行的 shell 脚本,如下所示:
```
#!/bin/bash
# 设置数据库连接参数
HOST=your_database_host
PORT=your_database_port
USER=your_database_user
PASSWORD=your_database_password
DB_NAME=your_database_name
# 获取当前时间
NOW=$(date +"%Y%m%d %H:%M:%S")
# 执行 SQL 语句
mysql -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME << EOF
UPDATE cust_info SET number_label = '号码标签', exchange_label = '局向标签';
COMMIT;
echo "$NOW 更新号码、局向标签:$(mysql -sN -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME -e "SELECT ROW_COUNT()") 条" >&2;
EOF
```
请注意,您需要将 `your_database_host`、`your_database_port`、`your_database_user`、`your_database_password` 和 `your_database_name` 替换为实际的数据库连接参数。
当您运行此脚本时,它将执行您提供的 SQL 语句,并将执行结果输出到标准错误流中。
相关问题
修改完整版的sql存储(积分兑换脚本),改写出可执行的shell message "Dateformat"("now"(),'yyyymmdd hh:nn:ss') || ' 更新动态星级用户:' || @@ROWCOUNT || ' 条' type info to client; --插入展示层 delete from "rpt_comm_yzf_ljh_yue_fee_show" where "month_id" = @month_id and "data_date" = @data_date and "is_flag" = 8; commit work; message "DATEFORMAT"("NOW"(),'YYYYMMDD HH:NN:SS') || '清空展示层清单:' || @@ROWCOUNT || ' 条' type info to client; insert into "rpt_comm_yzf_ljh_yue_fee_show"( "data_date","month_id","is_flag","type_desc","subst_name","seq_id","v1","v2" ) select @data_date,@month_id,8,'智能组网总量','广州',0,"count"(distinct "cust_name"),"sum"("price") from "rpt_wjq_jf_value_dhfz_list" where "gift_name" in( '60000积分兑换智能组网调测服务优惠包','20000积分兑换智能组网调测服务优惠包','40000积分兑换智能组网调测服务优惠包','10000积分兑换智能组网服务优惠包','30000积分兑换智能组网调测服务优惠包','30000积分兑换智能组网服务优惠包' ) group by "subst_name","seq_id"; commit work; message "Dateformat"("now"(),'yyyymmdd hh:nn:ss') || ' 插入展示层清单:' || @@ROWCOUNT || ' 条' type info to client end
您好,根据您提供的 SQL 语句,我为您编写了一个可执行的 shell 脚本,如下所示:
```
#!/bin/bash
# 设置数据库连接参数
HOST=your_database_host
PORT=your_database_port
USER=your_database_user
PASSWORD=your_database_password
DB_NAME=your_database_name
# 获取当前时间
NOW=$(date +"%Y%m%d %H:%M:%S")
# 执行 SQL 语句
mysql -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME << EOF
UPDATE rpt_wjq_jf_value_dhfz_list SET star_level = '智能组网总量' WHERE gift_name IN ('60000积分兑换智能组网调测服务优惠包','20000积分兑换智能组网调测服务优惠包','40000积分兑换智能组网调测服务优惠包','10000积分兑换智能组网服务优惠包','30000积分兑换智能组网调测服务优惠包','30000积分兑换智能组网服务优惠包');
UPDATE rpt_wjq_jf_value_dhfz_list SET star_level = '广州' WHERE subst_name = '广州';
UPDATE rpt_wjq_jf_value_dhfz_list SET seq_id = 0;
UPDATE rpt_wjq_jf_value_dhfz_list SET v1 = COUNT(DISTINCT cust_name);
UPDATE rpt_wjq_jf_value_dhfz_list SET v2 = SUM(price);
DELETE FROM rpt_comm_yzf_ljh_yue_fee_show WHERE month_id = @month_id AND data_date = @data_date AND is_flag = 8;
INSERT INTO rpt_comm_yzf_ljh_yue_fee_show (data_date, month_id, is_flag, type_desc, subst_name, seq_id, v1, v2)
SELECT @data_date, @month_id, 8, star_level, subst_name, seq_id, v1, v2 FROM rpt_wjq_jf_value_dhfz_list WHERE star_level = '广州' AND seq_id = 0;
COMMIT;
echo "$NOW 更新动态星级用户:$(mysql -sN -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME -e "SELECT ROW_COUNT()") 条" >&2;
echo "$NOW 清空展示层清单:$(mysql -sN -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME -e "SELECT ROW_COUNT()") 条" >&2;
echo "$NOW 插入展示层清单:$(mysql -sN -h$HOST -P$PORT -u$USER -p$PASSWORD -D$DB_NAME -e "SELECT COUNT(*) FROM rpt_comm_yzf_ljh_yue_fee_show WHERE month_id = @month_id AND data_date = @data_date AND is_flag = 8") 条" >&2;
EOF
```
请注意,您需要将 `your_database_host`、`your_database_port`、`your_database_user`、`your_database_password` 和 `your_database_name` 替换为实际的数据库连接参数。此外,您还需要将 `@month_id` 和 `@data_date` 替换为实际的参数值。
当您运行此脚本时,它将执行您提供的 SQL 语句,并将执行结果输出到标准错误流中。
message DATEFORMAT(NOW(),'YYYYMMDD HH:NN:SS') || 'execute:' || @@ROWCOUNT || 'pieces' type info to client;
这也是一个SQL语句,用于将当前时间和执行结果返回给客户端。其中,DATEFORMAT(NOW(),'YYYYMMDD HH:NN:SS')用于获取当前时间并格式化为字符串,@@ROWCOUNT用于获取最近一条执行的SQL语句所影响的行数。最后,使用"||"将它们连接起来,并添加一个类型为info的标识,表示这是一条信息类型的消息。这条消息将被发送到客户端。
阅读全文