summaryrefslogtreecommitdiffstats
path: root/system
diff options
context:
space:
mode:
authorTufan Barış YILDIRIM <tufanbarisyildirim@gmail.com>2013-12-19 18:48:00 +0100
committerTufan Barış YILDIRIM <tufanbarisyildirim@gmail.com>2013-12-19 18:48:00 +0100
commit72109068e391d67729d92d23ca47bd6373e64363 (patch)
tree68fdb698a17d97b7887cb1a53738827465befdcd /system
parent3cfd53937034d92ff15f9c2457a0f5bc1d80b0f6 (diff)
EXISTS / NOT EXISTS clause support for DB_query_builder.
Diffstat (limited to 'system')
-rw-r--r--system/database/DB_driver.php6
1 files changed, 4 insertions, 2 deletions
diff --git a/system/database/DB_driver.php b/system/database/DB_driver.php
index 72be14e4b..3c30c659c 100644
--- a/system/database/DB_driver.php
+++ b/system/database/DB_driver.php
@@ -1421,7 +1421,7 @@ abstract class CI_DB_driver {
*/
protected function _has_operator($str)
{
- return (bool) preg_match('/(<|>|!|=|\sIS NULL|\sIS NOT NULL|\sBETWEEN|\sLIKE|\sIN\s*\(|\s)/i', trim($str));
+ return (bool) preg_match('/(<|>|!|=|\sIS NULL|\sIS NOT NULL|EXISTS|\sBETWEEN|\sLIKE|\sIN\s*\(|\s)/i', trim($str));
}
// --------------------------------------------------------------------
@@ -1446,7 +1446,9 @@ abstract class CI_DB_driver {
'\s*<>?\s*', // <, <>
'\s*>\s*', // >
'\s+IS NULL', // IS NULL
- '\s+IS NOT NULL', // IS NOT NULL
+ '\s+IS NOT NULL', // IS NOT NULL
+ '\s+EXISTS', // EXISTS
+ '\s+NOT EXISTS', // NOT EXISTS
'\s+BETWEEN\s+\S+\s+AND\s+\S+', // BETWEEN value AND value
'\s+IN\s*\([^\)]+\)', // IN(list)
'\s+NOT IN\s*\([^\)]+\)', // NOT IN (list)