Очистите объект, содержащий условия WHERE, и используйте его с построителем запросов CodeIgniter.Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Очистите объект, содержащий условия WHERE, и используйте его с построителем запросов CodeIgniter.

Сообщение Anonymous »

Есть ли способ получить, какие предложения "where" я добавил в свой запрос?
Я использую оператор foreach для добавления столбцов, которые хочу добавить в предложениеwhere для текущего запроса, но поскольку предложение может быть пустым (столбцы не добавлены, 0 итераций в foreach), запрос будет извлекать все записи в базе данных, поскольку никаких ограничений там не было.
Конечно, я мог бы использовать логическую переменную, чтобы узнать, есть ли foreach выполняет как минимум 1 итерацию, но я хотел бы знать, можно ли получить информацию, связанную с запросом, который я делаю.
Мой код выглядит примерно так:

Код: Выделить всё

foreach ($columns as $column => $value) {
if ($column != '') {
$this->db->where($column, $value);
}
}
$this->db->get('mytable');
Некоторые объяснения:
Если $column — пустая строка, я не добавляю ее в запрос.
$columns var — это объект (stdClass).
Итак, если в запросе нет оператора «where», я не хочу получать какую-либо информацию с помощью $this->db->get(). Я ищу что-то вроде:

Код: Выделить всё

if (!empty($this->db->where_clauses()))
$this->db->get('mytable');
Есть ли что-то подобное?

Подробнее здесь: https://stackoverflow.com/questions/620 ... ters-query
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»