Php 如果不存在,则插入mysql;如果存在,则不更新
我有如下功能代码:Php 如果不存在,则插入mysql;如果存在,则不更新,php,mysql,codeigniter,Php,Mysql,Codeigniter,我有如下功能代码: $data_temp = $this->import_m->getPresensi()->result_array(); $tbl = "tb_kehadiran"; $tbl_temp = "tb_kehadiran_temp"; $db_mysql = $this->load->database('default',TRUE); $db_mysql->trans_start(); f
$data_temp = $this->import_m->getPresensi()->result_array();
$tbl = "tb_kehadiran";
$tbl_temp = "tb_kehadiran_temp";
$db_mysql = $this->load->database('default',TRUE);
$db_mysql->trans_start();
foreach($data_temp as $k => $v){
$dataTemp = array(
'colUserID' => $v['userID'],
'colDate' => $v['tanggal'],
'colJamMasuk' => $v['jam_masuk'],
'colJamKeluar' => $v['jam_keluar'],
'colTerlambat' => $v['late'],
'colLemburPagi' => $v['lembur_pagi'],
'colLemburSore' => $v['lembur_sore']
);
$sql = "INSER INTO $tbl (
'colUserID',
'colDate',
'colJamMasuk',
'colJamKeluar',
'colTerlambat',
'colLemburPagi',
'colLemburSore'
) VALUES (
$v[userID],
$v[tanggal],
$v[jam_masuk],
$v[jam_keluar],
$v[late],
$v[lembur_pagi],
$v[lembur_sore]
) ON DUPLICATE KEY UPDATE
'colJamMasuk' = $v[jam_masuk],
'colJamKeluar' = $v[jam_keluar],
'colTerlambat' = $v[late],
'colLemburPagi' = $v[lembur_pagi],
'colLemburSore' = $v[lembur_sore]
";
$db_mysql->query($sql);
}
$db_mysql->trans_complete();
$db_mysql->close();
结果错误为:
错误号码:1064
您的SQL语法有错误;检查与您的MariaDB服务器版本相对应的手册,以了解要使用的正确语法
“插入tb_kehadiran('colUserID',”在第1行
INSER INTO tb_kehadiran ( 'colUserID', 'colDate', 'colJamMasuk', 'colJamKeluar', 'colTerlambat', 'colLemburPagi', 'colLemburSore' ) VALUES ( 1, 2015-01-05, 07:01:00, 16:30:00, 00:00:00.000000, 00:28:16.000000, 00:00:43.000000 ) ON DUPLICATE KEY UPDATE 'colJamMasuk' = 07:01:00, 'colJamKeluar' = 16:30:00, 'colTerlambat' = 00:00:00.000000, 'colLemburPagi' = 00:28:16.000000, 'colLemburSore' = 00:00:43.000000
Filename: D:\xampp\htdocs\presensi\system\database\DB_driver.php
Line Number: 331
如果数据不存在,我希望我的源代码插入数据;如果数据存在,则不更新。
请帮助我。代码必须是这样的 插入表\u name set id=“some\u id”, name='某个名称' 关于重复密钥更新 name='某个名称'
此外,id字段必须定义为主键您在inserTIt的INSERT not INSERR中缺少一个t:)OP的语法与您的语法一样有效。@lelio faieta plz回显您的sql查询您在说什么?对不起,不必为您道歉。@willy andikaOP的问题已经解决。这是查询中inser vs insert语句的输入错误