如何在 where 子句上使用 if-else

时间:2021-07-09 02:27:45

标签: mysql laravel-8

我试图弄清楚当 lingkup 等于“desa”时如何在 where 子句上使用 if-else。 Where 子句仅 status = valid 但当 lingkup 为“kecamatan” where 子句 status = valid 且 status_kecamatan = valid 时。

$results = DB::table('tb_lapak')
    ->select('tb_surat.lingkup', 'tb_lapak.*')
    ->join('tb_surat', 'tb_lapak.kode_surat', '=', 'tb_surat.kode_surat')
    ->when('lingkup' === 'desa', function ($query) {
        return $query->where('status', '=', 'valid');
    })
    ->when('lingkup' === 'kecamatan', function ($query) {
        return $query->where('status', '=', 'valid');
        return $query->where('status_kecamatan', '=', 'valid');
    });

这是桌子

CREATE TABLE `tb_lapak` (
  `kode_lapak` int(11) NOT NULL,
  `kode_surat` int(11) NOT NULL,
  `tanggal` char(35) NOT NULL,
  `nik` char(35) NOT NULL,
  `keterangan` text NOT NULL,
  `status` enum('proses','valid') NOT NULL,
  `status_kecamatan` enum('proses','valid') NOT NULL,
  `create_at` timestamp NULL DEFAULT current_timestamp(),
  `kode_lingkup` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

CREATE TABLE `tb_surat` (
  `kode_surat` int(11) NOT NULL,
  `lingkup` enum('kecamatan','desa') NOT NULL,
  `nama_surat` varchar(225) NOT NULL,
  `output` varchar(225) DEFAULT NULL,
  `aktif` enum('Y','T') NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

1 个答案:

答案 0 :(得分:0)

这可能不需要样本数据,这只是一个逻辑问题

where (lingkup = 'desa' and status = 'valid')
   or (lingkup = 'kecamatan' and status = 'valid' and status_kecamatan = 'valid')
   or (lingkup not in ('desa', 'kecamatan'))