1

请帮我解决这个问题,当我运行这段代码时,出现错误count():参数必须是数组或者实现了Countable的对象,当我想获取no_st

public function get_no_st(Request $request){

        $no_org = null;
        $tgl    = $request->tgl ?: date('Y-m-d');
        $tgl    = Helper::saveDateIndo( $tgl );
        $max_no_st = $request->max_no_st ?: null;

        if ( $request->org == 'KPA'){
            $no_org = 'KPA.MBU';
        }else if ( $request->an ) {
            $no_org = $this->organisasi->select('kode_surat_atas_nama', 'kode_surat')->where('id', $request->org)->first();
            $no_org = ( count($no_org) > 0
                        ? ( trim($no_org->kode_surat_atas_nama) != null ? $no_org->kode_surat_atas_nama : $no_org->kode_surat )
                        : @$no_org->kode_surat );
        } else {
            $no_org = $this->organisasi->select('kode_surat')->where('id', $request->org)->first();
            $no_org = (count($no_org) > 0 ? $no_org->kode_surat : null);
        }

        if(!$max_no_st) {
            $max_no_st = $this->model->select('no_st_increment');
            if ( $request->org == 'KPA') {
                $max_no_st = $max_no_st->where('is_kpa', true);
            } else {
                $max_no_st = $max_no_st->where('pt_organisasi_id', $request->org);
            }
            if ( $tgl )
            {
                $max_no_st  = $max_no_st->where(DB::raw('EXTRACT( YEAR FROM tgl_awal )'), date('Y', strtotime($tgl)) );
            }
            $max_no_st  = $max_no_st->max('no_st_increment') + 1;
        }

        $no_st      = 'ST-'.$max_no_st.'/'.($no_org ?: '-').'/'.date('n/Y', strtotime( $tgl ));

        return $no_st;
    }
4

3 回答 3

1

您正在尝试计算对象类型数据,但您只能计算一个数组。如果您仍想计算对象的属性,您可以简单地将对象转换为数组。像这样:

count((array) $no_org);

这将返回 $no_org 的属性总数;

于 2020-01-10T06:53:07.607 回答
0

这是因为您使用的 PHP 版本和 Laravel 版本。

在这里阅读

您可以将结果转换为数组。

$no_org = ( count((array)$no_org)
...
于 2020-01-10T02:20:02.780 回答
0

根据错误信息,你是 count()无法实现 Countable 的东西。

->first()将返回一个无法实现可数的对象。

->get()将返回一个可数的集合。

但是,您只需要找到 的一个对象organisasi,因此您可以empty() 像这样使用:

empty($no_org)
于 2020-01-10T02:21:46.117 回答