我正在尝试使用以下代码从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中运行上述查询时,它工作得很好。请帮我解决问题
答案 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);