插入查询不在codeigniter中工作

时间:2013-08-15 09:18:11

标签: php mysql codeigniter

我正在尝试使用以下代码从codeigniter运行插入查询

$this->db->query($query);

但我收到以下错误:

  

错误号码:1064

     

您的SQL语法有错误;检查手册   对应于您的MySQL服务器版本,以便使用正确的语法   靠近''第4行

INSERT INTO order_bank 
    (creation_date, order_type, so_no, 
    material_no, description, order_qty, no_of_panels, 
    division, job_number, customer_group, sales_office, 
    sales_group, project_name, project_manager, 
    net_value_myr, credit_status, so_delivery_date, 
    order_delivery_date) 
VALUES ( '2013-07-01', 'ZTOR', 3058627219, 
    101900000000, 'SUPPLY, MODIFY, INSTALL TEST VCU', 
    1, 0, 'AIS (TSM)', 'SC139203J01', 'Industry', 
    'SEA', 'DOM', 'MELAKA', 
    'Phua Tiang Hai', 42954.55, '', '2013-07-11', 
    '2013-07-05');
  

文件名:C:\ wamp \ www \ system \ database \ DB_driver.php
  行号:330

但是当我在phpmyadmin中运行上述查询时,它工作得很好。请帮我解决问题

4 个答案:

答案 0 :(得分:3)

使用Codeigniter提供的有效记录,这将更加安全和简单!

http://ellislab.com/codeigniter/user-guide/database/active_record.html

实施例: -

$this->db->set('description', $description);
$this->db->set('order_qty', $order_qty);
$this->db->set('no_of_panels', $no_of_panels);
$this->db->set('division', $division);
$this->db->set('job_number', $job_number);
$this->db->set('customer_group', $customer_group);
$this->db->set('sales_office', $sales_office);
$this->db->set('sales_group', $sales_group);
$this->db->set('project_name', $project_name);
$this->db->set('project_manager', $project_manager);
$this->db->set('net_value_myr', $net_value_myr);
$this->db->set('credit_status', $credit_status);
$this->db->set('so_delivery_date', $so_delivery_date);
$this->db->set('order_delivery_date', $order_delivery_date);
$this->db->insert('order_bank');

或者如果您的数据存储在数组中,那么您只需运行

即可
$this->db->insert('order_bank', $data);

答案 1 :(得分:2)

您必须在控制器类或自动加载文件中加载数据库库。

在自动加载文件中:

$autoload['libraries'] = array('database');

或在控制器类中:

$this->load->library("database");

答案 2 :(得分:0)

42954.55必须是'42954.55'。忽略活动记录示例,因为这与问题无关,这就是此查询失败的原因。

答案 3 :(得分:0)

尝试像这样的东西

$data = array(
   'user_id' => '$user_id' ,
   'photo_id' => '$photo_id' ,
   'album_id' => '$album_id'
);

$this->db->insert('photo_album', $data);