防止将空数组插入数据库。 PHP

时间:2015-12-15 01:16:40

标签: php mysql arrays oracle

我想问一下数组。如何防止空数组插入数据库?我已经使用!empty,但它仍然无效。 如果我移动

  

for($ i = 0; $ i< count($ spm); $ i ++)

if(!empty)之前它有错误。请帮忙。

<?php
 if(!empty($spm)&&$total_spm==0)

        {

            for ($i = 0; $i < count($spm); $i++) {

        $spmSubjek =($spm[$i]);
        $gredSubejek = ($gredSPM[$i]);  


        $sqlInsertSpm=OCIParse($c,$a="INSERT INTO E_PENDIDIKAN_PELAJAR
                                                        (
                                                            DIDIK_NOMKPB,
                                                            DIDIK_KOD_PERIKSA,
                                                            DIDIK_GRED,
                                                            DIDIK_NAMA,
                                                            DIDIK_KTRGN,
                                                            DIDIK_THN_DARI,
                                                            DIDIK_TRKH_UPD,
                                                            DIDIK_CREATED_USER,
                                                            DIDIK_CREATED_DATE,
                                                            DIDIK_JENIS_SEKOLAH
                                                        )
                                                        VALUES
                                                        (
                                                            '$nomkpb',
                                                            '0',
                                                            '$gredSubejek',
                                                            '$spmSubjek',
                                                            '$spmSubjek',
                                                            '$year_spm_bm',
                                                            to_date('".$curr_date."','dd-mm-rrrr hh:mi AM'),
                                                            'IPSWEB',
                                                            to_date('".$curr_date."','dd-mm-rrrr hh:mi AM'),
                                                            '$jenis_sekolah'
                                                        )
                                                        ");
            OCIExecute($sqlInsertSpm);
            OCICommit($c);



            }}
            ?>

1 个答案:

答案 0 :(得分:0)

使用foreach代替for循环。如果数组为空,foreach将执行内部代码零次,即您不必阻止任何内容。

foreach ($spm as $i => $spmSubjek) {
    // not needed, it is done by foreach for you $spmSubjek =($spm[$i]); 
    $gredSubejek = ($gredSPM[$i]); // still needed, but $i is taken from foreach
    ...
}

更多信息请参阅文档:http://php.net/manual/en/control-structures.foreach.php