首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过psql脚本返回值判断Greenplum任务是否执行成功

背景 由于psql在执行sql脚本文件的过程中,默认是遇到错误继续执行不停止,所以导致我们无法通过其执行的最终返回值来判断该脚本是否有发生错误。...0 [gpadmincloud@mdw-snova-90g4jkrm ~]$ 经过测试,确实是报错了,但是执行并没有中断,而是继续执行了下去。...相应的,最终返回值也是不符合预期的0(true),这样则无法根据最终返回值来判断SQL脚本是否执行成功了。所以,这里我们介绍两个方案来实现该需求。...1 [gpadmincloud@mdw-snova-90g4jkrm ~]$ 可以看到,psql -c的方式,遇到错误会立刻中断,并返回一个非0(false)的值,可以满足我们通过返回值来判断SQL是否全部执行成功的需求...特别注意 不管是使用方案一还是方案二,如果想确认SQL最终是否执行成功,那么一定要要判断返回值是否为0。因为与其他语言不同的是,bash shell的返回值为0才是成功,非0则是失败。

2.4K2816
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    直接执行成功,crontab却执行失败

    背景 程序员在日常工作中,为了解放人力提高效率,常常需要把一些周期性的任务例行化执行,比如每天发送一封数据报表邮件,每小时备份一次日志文件等。...问题 写了一个汇总数据并且发送邮件的shell脚本(/tmp/email.sh),手工执行成功的,但是通过crontab执行却总是失败。 shell脚本如下: #!...crontab执行发送失败的邮件如下: ? 分析 crontab执行发送的错误邮件,标题中文部分为乱码,怀疑是环境变量LANG不支持中文,于是来简单测试一下: #!.../bin/bash echo $LANG >> /tmp/test_out crontab定时执行输出结果为: [空] 直接执行输出结果为: en_US.UTF-8 解决 方案就很明确了,强制设置环境变量...OK,但是crontab死活不执行时。

    4.4K20

    PHP判读MySQL是否执行成功

    update 语句等会对数据表进行修改的语句 在mysql_query($sql);后面加上 $result = mysql_affected_rows();  如果$result 值为-1表明语句没有成功执行...,可能是语句格式有问题等等; 如果$result 值为0 表明语句成功执行,但是update并没有改变数据表任何一个字段的值; 如果$result值为1 表明语句成功执行, 而且update改变了数据表的某个或者多个字段的值...等等查询类不对数据表任何值进行修改的语句 在 mysql_query($sql);后面加上 $result = mysql_num_rows(mysql_query); 如果$result 值为-1,表明语句没有成功执行...,可能是语句格式有问题等等, 如果$result 值为0,表明语句成功执行,但是查询结果为空 如果$result 值为x(x>0),表明成功执行,且查询结果中有x条记录 本文采用 「CC BY-NC-SA

    1.7K20

    Task成功执行的结果处理

    前言 在文章Task执行流程 中介绍了task是怎么被分配到executor上执行的,本文讲解task成功执行时将结果返回给driver的处理流程。...Driver端接收task完成事件 在executor上成功执行完task并拿到serializedResult 之后,通过CoarseGrainedExecutorBackend的statusUpdate...driver远程去抓取结果之间,如果运行task的机器挂掉 该机器的BlockManager已经刷新掉了Task执行结果 获取结果远程获取结果成功后删除远程BlockManager对应的结果,则直接返回其序列化后的结果...maybeFinishTaskSet() } 逻辑很简单,标记task成功运行、跟新failedExecutors、若taskSet所有task都成功执行的一些处理,我们具体看看是怎么通知...若完成的task数和totalTasks数相等,则该job成功执行,打印日志完成。

    1.5K40

    Moq基础 判断方法被执行

    本文是在Moq基础(五)的基础上做的补充 例如有方法 Foo 支持注入接口 IFoo 需要判断在 Foo 方法里面调用 IFoo 的 Foo 方法几次 public class Foo...mock.Setup(fake => fake.Foo()); 然后调用 foo 的需要被测试方法 foo.A(); 接着判断这个...IFoo 的 Foo 被调用多少次 // 判断在调用 A 之后调用了 IFoo 的 Foo 方法多少次 mock.Verify...那么在实际运行被测试类的方法之后,就可以通过 Verify 判断某个方法被调用了多少次 mock.Verify(fake => fake.虚拟的方法, 被调用多少次); 这里的被调用多少次是可以是 Times...,需要注意,在 Verify 里面需要调用被虚拟的方法是用来做参数判断的,可以判断传入了某个参数的方法调使用多少次的方法 如果不满足就会在 Verify 方法抛出 MockException 在里面会说到要求的是什么

    1.4K20

    ThreadPool怎样判断子线程全部执行完毕

    多线程执行顺序是不确定的, 那使用ThreadPool怎样判断子线程全部执行完毕?...                {                     ThreadPool.QueueUserWorkItem(new WaitCallback(Auto), i);//线程池指定线程执行...这句要改                    Console.ReadLine();         }         public static void Auto(object i)//多线程执行的方法...因为这时是 主线程+子线程 这些线程的执行顺序不确定,可能主线程老早就执行了。也就说可能结束了 这三个字很早就会输出。 3、主题 保证 结束了 在最后输出。 方法1: //这是主线程,一直都会执行。...                {                     ThreadPool.QueueUserWorkItem(new WaitCallback(Auto), i);//线程池指定线程执行

    1.5K20

    如何判断线程池任务执行完?

    1.需求分析 线程池的使用并不复杂,麻烦的是如何判断线程池中的任务已经全部执行完了?...因为我们要等所有任务都执行完之后,才能进行数据的组装和返回,所以接下来,我们就来看如何判断线程中的任务是否已经全部执行完?...2.实现概述 判断线程池中的任务是否执行完的方法有很多,比如以下几个: 使用 getCompletedTaskCount() 统计已经执行完的任务,和 getTaskCount() 线程池的总任务进行对比...3.具体实现 3.1 统计完成任务数 通过判断线程池中的计划执行任务数和已完成任务数,来判断线程池是否已经全部执行完,如果计划执行任务数=已完成任务数,那么线程池的任务就全部执行完了,否则就未执行完。...只关注数量,不关注(具体)对象,所以这些方式都有可能受到外界代码的影响,因此使用 FutureTask 等待具体任务执行完的方式是最推荐的判断方法

    21220

    ERP系统上线成功与失败是否存在判断标准?

    一、没有“预期”何谈成功 评判项目是否成功与否,往往是软件商和用户之间纠缠不清的问题。翻开现代汉语大词典,查查什么是成功成功者,“获得预期的成果”是也。这里的关键词是“预期”,没有预期就无从谈成功。...总之,没有量化的目标,就无法评判是否成功。 国外有一些报道评论ERP的成功率时,是以“是否按进度完成”,“预算是否超支”来衡量的。例如有报道说:“国际上,工业研究表明:ERP项目70%以上都不成功。...三、评判成功的共性标准 各个企业的目的目标不同,成功的标准也可能不同。但是,其中还是有一些共性的评价参数,参考平衡记分法的精神,归纳为四类。 (1)项目进程 一种结果可以是通过不同的过程得来的。...建立了工作准则与工作规程,并已严格执行。 有一支培训教员,有结合企业实际编写的培训教材,接受培训的员工比例不断扩大。 提出了下一阶段工作建议,有了新的目标;追求卓越,永无止境。...ABCD考评表的方法条目过多,执行起来很烦琐。因此,如何评判ERP项目成败,还需要国内企业不断创新,提出与时俱进的新方案。 声明:本文版权归原作者所有,如有侵权请联系删除。

    98211

    如何判断线程池任务执行完?

    1.需求分析 线程池的使用并不复杂,麻烦的是如何判断线程池中的任务已经全部执行完了?...因为我们要等所有任务都执行完之后,才能进行数据的组装和返回,所以接下来,我们就来看如何判断线程中的任务是否已经全部执行完?...2.实现概述 判断线程池中的任务是否执行完的方法有很多,比如以下几个: 使用 getCompletedTaskCount() 统计已经执行完的任务,和 getTaskCount() 线程池的总任务进行对比...3.具体实现 3.1 统计完成任务数 通过判断线程池中的计划执行任务数和已完成任务数,来判断线程池是否已经全部执行完,如果计划执行任务数=已完成任务数,那么线程池的任务就全部执行完了,否则就未执行完。...只关注数量,不关注(具体)对象,所以这些方式都有可能受到外界代码的影响,因此使用 FutureTask 等待具体任务执行完的方式是最推荐的判断方法。

    38540
    领券