请帮我解决这个问题当我运行这段代码时,出现了一个错误count ():当我想要获取no_st时,参数必须是一个数组或实现Countable的对象
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;
}发布于 2020-01-10 14:53:08
您正在尝试计算对象类型数据,但您将只能计算数组。如果您仍然想计算一个对象的属性,您可以简单地将该对象转换为一个数组。如下所示:
count((array) $no_org);返回$no_org的属性总数;
发布于 2020-01-10 10:20:03
发布于 2020-01-10 10:21:46
根据错误消息,您是count()不能实现Countable的东西。
->first()将返回一个不能实现countable的对象。
->get()将返回一个可以计数的集合。
但是,您只需要找到organisasi的一个对象,所以您可以像这样使用empty():
empty($no_org)https://stackoverflow.com/questions/59674675
复制相似问题