Codeigniter 3 use of db->like for multiple columns results in an SQL related error

Codeigniter 3 use of db->like for multiple columns results in an SQL related error



I am working on a basic blog application in Codeigniter 3.1.8.



The search posts functionality gives me unexpected trouble:


You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '* LIKE '%expression%' ESCAPE '!'' at line 3

SELECT * FROM `posts` WHERE * LIKE '%expression%' ESCAPE '!'



The search() method in the Posts model looks like this:


search()


public function search($expression)
$this->db->like('*', $expression);
$query = $this->db->get('posts');
return $query->result();



The relevant table fields are:



enter image description here



Where is my mistake?






$this->db->like('*', $expression); what is * ?

– sagi
Sep 16 '18 at 9:42


$this->db->like('*', $expression);






@sagi it is all columns

– Razvan Zamfir
Sep 16 '18 at 9:46






This is not possible in SQL. * is used in select list

– sagi
Sep 16 '18 at 9:47




2 Answers
2



In the new CodeIgniter release (3.1.9), there was a fix for an unwanted typo ... Inside system/database/DB_query_builder.php at line #973 I believe:


system/database/DB_query_builder.php



This :

case 'before':
$v = "%'$v'"; // <- Check here
break;



case 'before':
$v = "%'$v'"; // <- Check here
break;



Was changed to this:

case 'before':
$v = "'%$v'"; // <- The fix
break;



case 'before':
$v = "'%$v'"; // <- The fix
break;



Try to do this change and see if this fixes your issue or not.



EDITED



After seeing your code, please don't use * as a field name, you have to specify what field is used for the search ... For instance, if you want to search in titles, descriptions and contents, you may proceed as this:


*


$query = $this->db->like('title', $expression)
->or_like('description', $expression)
->or_like('content', $expression);



Then the rest of your code. Give it a shot.



You need to use column/expression instead of *:


*


SELECT * FROM `posts` WHERE * LIKE '%expression%' ESCAPE '!'
=>
SELECT * FROM `posts` WHERE column_name LIKE '%expression%' ESCAPE '!';



I need to seelct from all columns in the posts table



Then you could use something like(be aware of poor performance because CONCAT and LIKE '%exp' make it nonSARGable.


CONCAT


LIKE '%exp'


SELECT * FROM `posts`
WHERE CONCAT(col1,col2, col3, ...) LIKE '%expression%' ESCAPE '!'



To avoid potential problems with CONCAT you should add separator:


CONCAT


SELECT * FROM `posts`
WHERE CONCAT(col1,'^',col2,'^',col3, ...) LIKE '%expression%' ESCAPE '!'






I need to seelct from all columns in the posts table

– Razvan Zamfir
Sep 16 '18 at 9:42






@sagi Then he needs to add separator that is unlikely to exist in any column. I will update my answer.

– Lukasz Szozda
Sep 16 '18 at 9:47






Also, I would like a Codeigniter specific solution.

– Razvan Zamfir
Sep 16 '18 at 9:48






@RazvanZamfir Sorry, I don't know PHP. I am sure it is possible to translate expression CONCAT(col1,'^',col2,'^',col3, ...) to your ORM. As last resort you could always execute native query.

– Lukasz Szozda
Sep 16 '18 at 9:53



CONCAT(col1,'^',col2,'^',col3, ...)



Thanks for contributing an answer to Stack Overflow!



But avoid



To learn more, see our tips on writing great answers.



Required, but never shown



Required, but never shown




By clicking "Post Your Answer", you agree to our terms of service, privacy policy and cookie policy

Popular posts from this blog

𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

Crossroads (UK TV series)

ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế