Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: php mysql галочка null пустое поле

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: как поставить запросом галку null
Телевизор
Отправлено: 10 Июня, 2012 - 17:19:13
Post Id



Посетитель


Покинул форум
Сообщений всего: 369
Дата рег-ции: Март 2010  
Откуда: с яндекса


Помог: 3 раз(а)




не могу сообразить подскажите,
в mysql запросе UPDATE устанавливаю переменной 1 или null. (в mysql по умолчанию null)
но этот null галочка не ставится а пишетсмя значение 0

Поможите пожлста

PHP:
скопировать код в буфер обмена
  1. $query = "UPDATE table
  2. SET direct_link = ".mysql_real_escape_string((isset($_POST['direct_link']) ? 1 : null))."
  3. WHERE `id` = '".mysql_real_escape_string($_GET['f'])."';";


вот этот null записывается как 0 а нужно чтобы в mysql ставилась галочка null поумолчанию

(Отредактировано автором: 10 Июня, 2012 - 17:21:11)

 
 Top
OrmaJever Модератор
Отправлено: 10 Июня, 2012 - 17:49:16
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




Ну дак нужно таблицу так создать что бы было разрешено этому полю быть null


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
Телевизор
Отправлено: 10 Июня, 2012 - 17:52:49
Post Id



Посетитель


Покинул форум
Сообщений всего: 369
Дата рег-ции: Март 2010  
Откуда: с яндекса


Помог: 3 раз(а)




OrmaJever пишет:
Ну дак нужно таблицу так создать что бы было разрешено этому полю быть null

разрешено - я установил в таблице в поле null по умолчанию,
а в скрипте не получается чтобы был null по умолчанию
 
 Top
OrmaJever Модератор
Отправлено: 10 Июня, 2012 - 18:04:28
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




Запрос на создание таблицы можно?


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
Телевизор
Отправлено: 10 Июня, 2012 - 18:34:32
Post Id



Посетитель


Покинул форум
Сообщений всего: 369
Дата рег-ции: Март 2010  
Откуда: с яндекса


Помог: 3 раз(а)




Блииин самое главное не сказал простите пожалуйста,
когда без тернарного условия просто sql запрос ввида
CODE (SQL):
скопировать код в буфер обмена
  1. ... UPDATE TABLE
  2. SET direct_link = NULL
  3. WHERE `id` ....


То все работает и null по умолчанию устанавливается а вот с тернарным условием не получается извращался как мог...

OrmaJever пишет:
Запрос на создание таблицы можно?

Спойлер (Отобразить)
 
 Top
Мелкий Супермодератор
Отправлено: 10 Июня, 2012 - 18:49:38
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Приведение типов, приведение типов.
null становится 0 после mysql_real_escape_string. Чтобы сделать поле null'ом надо и передавать самим запросом null, а не значение php. Чтобы в запросе и было написано set `field`=null.
Проще говоря, вставляйте строку 'null'


-----
PostgreSQL DBA
 
 Top
Телевизор
Отправлено: 10 Июня, 2012 - 19:48:04
Post Id



Посетитель


Покинул форум
Сообщений всего: 369
Дата рег-ции: Март 2010  
Откуда: с яндекса


Помог: 3 раз(а)




OrmaJever , Мелкий
понел спасибо

получается что оптимальное решение такое ?
PHP:
скопировать код в буфер обмена
  1. // работает
  2. $query = "UPDATE table SET ".(isset($_POST['direct_link']) ? 'direct_link = 1' : 'direct_link = null')." WHERE `id` ... ;";

(Отредактировано автором: 10 Июня, 2012 - 20:14:21)

 
 Top
OrmaJever Модератор
Отправлено: 10 Июня, 2012 - 20:03:38
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




даже короче можно, что бы не повторятся
PHP:
скопировать код в буфер обмена
  1. $query = "UPDATE table SET direct_link = ".(isset($_POST['direct_link']) ? '1' : 'null')." WHERE `id` ... ;";
  2.  


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
Телевизор
Отправлено: 10 Июня, 2012 - 20:24:27
Post Id



Посетитель


Покинул форум
Сообщений всего: 369
Дата рег-ции: Март 2010  
Откуда: с яндекса


Помог: 3 раз(а)




ой да да именно так спасибо OrmaJever
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB