codeigniter - 将数据插入oracle数据库

时间:2015-05-22 11:57:32

标签: php oracle codeigniter

我在使用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")');

但在这两种情况下我都收到以下错误:

Database error message screenshot

2 个答案:

答案 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