Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2009.10.25;
Скачать: CL | DM;

Вниз

Не пойму с поведением SQL   Найти похожие ветки 

 
DillerXX ©   (2009-08-23 03:52) [0]

Какое-то странное поведение.
CREATE TABLE IF NOT EXISTS `test` (
 `id` int(11) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=cp1251;

INSERT INTO `test` (`id`) VALUES
(11);


И теперь мы делаем следующий запрос: SELECT * FROM `test` WHERE `id` = "11aaaaaa"
Вы знаете, у меня он будет не пустым... не понимаю ничего, это как-то странно. Может у меня под виндой версия мускуля палёная?.. Может кто-нибудь у себя попробовать? Всё началось в того, что эта сволочь по запросу "11\"" находила какой-то результат, а дальнешие скрипты падали нафиг.
Спасибо.


 
Inovet ©   (2009-08-23 10:57) [1]

Может с базой непорядок? Бэкап, рестор наверно есть в Мускл.


 
sniknik ©   (2009-08-23 11:14) [2]

> CHARSET=cp1251
попробуй поменять на utf8, у mysql проблемы с кодировками, и бардак с ними в версиях и драйверах доступа.


 
DillerXX ©   (2009-08-23 12:16) [3]

Нет... всё равно находит запись 11. Блин. Всех ненавижу. Столько времени на дебаг убил, чего только не перерыл с этими кавычками, а тут мускуль тупит.


 
DillerXX ©   (2009-08-23 12:34) [4]

Поставил MySQL из Zend Framework, всё равно та же фигня.


 
Anatoly Podgoretsky ©   (2009-08-23 12:56) [5]

> DillerXX  (23.08.2009 12:34:04)  [4]

Не тот SQL используй, вот и вся проблема.


 
antonn ©   (2009-08-23 13:04) [6]

к числовому типу в запросе применяешь строку?

а вот так найдет?
SELECT * FROM `test` WHERE `id` = "22aaaaaa"


 
sniknik ©   (2009-08-23 13:40) [7]

> к числовому типу в запросе применяешь строку?
ну и что? правильной реакцией была бы ошибка, а не "тихое" приведение типа очевидно нечислового.


 
sniknik ©   (2009-08-23 14:28) [8]

кстати если в приведенном запросе int поменять на VarChar, все остальное не трогать, то любое обращение потом к таблице выдает
> EOleException : Поставщик данных или другая служба вернули состояние E_FAIL
это если через драйвер ODBC 5.1 подключаться, через 3й нормально...
в общем правильно его назвали - недобаза. :).


 
antonn ©   (2009-08-23 14:32) [9]

или "недопровайдер" :)

для веба - само то. тока инструкции надо читать :)


 
Anatoly Podgoretsky ©   (2009-08-23 14:43) [10]

> antonn  (23.08.2009 14:32:09)  [9]

Для Вебе есть другие не менее приемлемые СУБД - Firebird, PostGre, MSSQL


 
antonn ©   (2009-08-23 14:46) [11]

ну лично мне мускла хватает, стоит на подавляющем большистве хостерских площадок. pgsql использова лишь пару раз, и то потому что заставили :)
хостинг с mssql уже дороже


 
Anatoly Podgoretsky ©   (2009-08-23 14:50) [12]

> antonn  (23.08.2009 14:46:11)  [11]

А про Firebird почему молчишь?


 
antonn ©   (2009-08-23 14:55) [13]

в вебе ни разу не сталкивался


 
sniknik ©   (2009-08-23 16:46) [14]

> или "недопровайдер" :)
можно и так, но учитывая что оба и база и провайдеры "одних рук дело" это одно и тоже.

и кстати забыл в предыдущем посте указать, если ставить вместо cp1251 utf8 то уже оба провайдера более менее работают (не без "закидонов", есть вариант когда параметры не сходятся кодировкой с текстом запроса, но тем не менее без непонятых E_FAIL)
говорю же, бардак у них с этим делом... (или, если говорить "линукс-корректно", настраивается как угодно, зависит от кривизны рук. ;о))


 
blackman ©   (2009-08-23 20:41) [15]

"11aaaaaa" - кавычки убери и оставь только 11. У тебя тип int.
В твоем случае преобразует только 11, aaaaaa - отбросит
В сущности, это твоя ошибка и в зависсимости от настроек мускула она может игнорироваться


 
antonn ©   (2009-08-23 21:23) [16]

имхо если идет сравнивание с данными то кавычки лучше всегда ставить :)


 
blackman ©   (2009-08-23 21:34) [17]

antonn ©   (23.08.09 21:23) [16]
C какого бодуна это лучше для int ?
Что бы было медленнее ? :)


 
antonn ©   (2009-08-23 21:37) [18]

во-первых оно может выглядеть так, сравнить два поля
SELECT * FROM `test` WHERE `id` = value

во-вторых при отсутсвии такого поля оно выматерится :)

конечно тут число, и можно дополнительно фильтровать данные, а можно завести привычку экранировать именно данные и не париться :)


 
blackman ©   (2009-08-23 21:46) [19]

antonn ©   (23.08.09 21:37) [18]
Выматерится не обязательно. Ежели в инете...Апач, PHP и Mysql, то возможно "мат" и подавляется.
Но, конечно дело привычки...


 
DillerXX ©   (2009-08-24 01:29) [20]

Теперь буду фильтровать int поля вручную. Но вообще, это ни разу не правильно. SQL сервер не должен как-то вычленять численное начало из строки, а сразу возвращать нулевой результат.

Ещё одну вещь хочу узнать. Я правильно понимаю, что SELECT COUNT(*) ... и SELECT COUNT("") ... при любых раскладах работают за одинаковое время?


 
antonn ©   (2009-08-24 01:39) [21]

вообще первый раз вижу count("") :)
в нем же перечисляешь названия столбцов


 
Дмитрий С ©   (2009-08-24 09:28) [22]


> Ещё одну вещь хочу узнать. Я правильно понимаю, что SELECT
> COUNT(*) ... и SELECT COUNT("") ... при любых раскладах
> работают за одинаковое время?

Нет.
Mysql оптимизирует запросы вида SELECT COUNT(*) FROM `table`.
В случае SELECT COUNT("") FROM `table` - будет перебор и подсчет.


 
sniknik ©   (2009-08-24 10:00) [23]

> а сразу возвращать нулевой результат.
нет, он должен возвращать ошибку о невозможности конвертации... или будут трудноуловимые логические баги, т.к. явная ошибка скрывается и подменяется на какой то результат.


 
DillerXX ©   (2009-08-24 11:05) [24]


> Mysql оптимизирует запросы вида SELECT COUNT(*) FROM `table`.
>
> В случае SELECT COUNT("") FROM `table` - будет перебор и
> подсчет.


Вот как... спасибо большое, буду знать.


 
DillerXX ©   (2009-08-25 21:29) [25]

Скажите, а во всё том же MySQL возможно ли присвоить полю значение по-умолчанию NOW() ? А то немного добивает в INSERT дописывать NOW() каждый раз.


 
antonn ©   (2009-08-25 21:52) [26]

вроде как нельзя.


 
Ega23 ©   (2009-08-26 09:45) [27]

Если в MySQL разрешено в качестве default-значений использовать функции - то можно.
Если не разрешено - нельзя.


 
atruhin ©   (2009-08-26 15:15) [28]

> [23] sniknik ©   (24.08.09 10:00)

Тут дело даже не в трудноуловимых багах, а в том что, в стандарте четко определенно:
при сравнении строки и числа, строка приводится к числу.
Хотя у MySQL к стандартам отношение особое. За что нравится Firebird, один из основных принципов,
везде где только возможно следует стандарту.


 
antonn ©   (2009-08-26 15:23) [29]


> при сравнении строки и числа, строка приводится к числу.

приводить можно по-разному :)


 
DillerXX ©   (2009-08-26 18:40) [30]

SELECT 1 = "1aaaa"
вернёт 1
странно это как-то...


 
DillerXX ©   (2009-08-27 18:02) [31]

Вот ещё вопрос. Пусть в таблице 1млн записей. Как будет работать запрос

> SELECT `id` FROM `tbl` ORDER BY RAND() LIMIT 30

в постгресе и мускуле?


 
antonn ©   (2009-08-27 18:13) [32]

в мускле это выберет все записи в кеш, и оттуда выберет случайные 30. Вроде как :)
поэтому rand() одна из не рекомендуемых функций


 
М. Береговой   (2009-08-28 00:33) [33]


> DillerXX ©   (26.08.09 18:40) [30]
> SELECT 1 = "1aaaa"
> вернёт 1
> странно это как-то...

Мне кажется ничего странного нет... У вас тип данных объявлен как int(11), как числовой тип. А в ячейке находится строковое значение "1аааа", которое будет парсировано (как в javascript parseInt("1aaaa")->1) в числовой, что дает 1. Теперь выражение SELECT 1 = "1aaaa" будет преобразовано в SELECT 1 = 1, а поскольку 1=1 логическое, то результат будет типа bit (как в MS SQL), у которого только два значения 0 и 1. Поскольку 1=1 истино, то результат будет 1.

Есть такое мнение.



Страницы: 1 вся ветка

Текущий архив: 2009.10.25;
Скачать: CL | DM;

Наверх




Память: 0.52 MB
Время: 0.041 c
10-1160553379
Alex_KV
2006-10-11 11:56
2009.10.25
Не паботает Invoke


6-1208844661
berlio
2008-04-22 10:11
2009.10.25
IdSNTP от Indy10 не хочет работать через прокси


2-1251091182
Interesting
2009-08-24 09:19
2009.10.25
Как возвести число в степень?


2-1251107698
SkyN
2009-08-24 13:54
2009.10.25
Как отловить причину закрытия программы?


2-1251462711
denis_lunev
2009-08-28 16:31
2009.10.25
Сохранение изменений свойств в EDIT





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский