我在使用codeigniter将数据插入到oracle数据库(11g)时面临一些问题。
首先是我的database.php文件:
$active_group = 'default';
$active_record = TRUE;
$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'turjo';
$db['default']['password'] = '123';
$db['default']['database'] = '';
$db['default']['dbdriver'] = 'oci8';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = FALSE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = '';
$db['default']['char_set'] = 'utf8';
$db['default']['dbcollat'] = 'utf8_general_ci';
$db['default']['swap_pre'] = '';
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;
然后在我的控制器中..
$conn = oci_connect('turjo', '123', 'localhost');
if($conn) {
echo "connected";
}
else {
echo "not";
}
给了我connected
。
$query = $this->db->query('SELECT * FROM METERREADING_CIBL');
$data = $query->result_array();
print_r($data);
给了我一个数组Array ( [0] => Array ( [RDGN_ID] => 1 [REB_OFF_CODE] => 01 [BILL_MONTH] => JAN [METER_NO] => 1122 [BOOK_NO] => 1122 [ACC_NO] => 1122 [CRDGN] => 1 [RDGN_FLAG] => 1 [RDGN_REF_NUM] => 1 [REC_STATUS] => 1 ) )
现在我想在表METERREADING_CIBL
我尝试的是:
$data['REB_OFF_CODE'] = "01";
$data['BILL_MONTH'] = "FEB";
$data['METER_NO'] = "1122";
$data['BOOK_NO'] = "1122";
$data['ACC_NO'] = "1122";
$data['CORDGN'] = 1;
$data['RDGNFLAG'] = "1";
$data['RDGN_REF_NUM'] = "1";
$data['REC_STATUS'] = "1";
$this->db->insert('METERREADING_CIBL', $data);
和另一种方式:
$this->db->query('INSERT INTO "METERREADING_CIBL" ("REB_OFF_CODE", "BILL_MONTH", "METER_NO", "BOOK_NO", "ACC_NO", "CORDGN", "RDGNFLAG", "RDGN_REF_NUM", "REC_STATUS") VALUES ("02", "FEB", "1122", "1122", "1122", "1", "1", "1", "1")');
但在这两种情况下我都收到以下错误:
答案 0 :(得分:0)
一个可能的原因:
您的RGDN_ID
字段未设置为自动填充。
它相当于插入MySQL表中的主键没有AUTO_INCREMENT
,而你自己也没有提供该ID。
请你的DBA帮助你。
<强>更新强>
您尝试插入的字段名称中存在拼写错误:
RDGNFLAG
vs RDGN_FLAG
CORDGN
vs CRDGN
答案 1 :(得分:0)
双引号问题。复制语句并在SQL Developer上运行。你会发现一个无效的字符(&#34;&#34;)
有关详细信息,请参阅此链接 CodeIgniter - ActiveRecords and Oracle - configuration