Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191

Проверка на существовании имени в БД

16.10.2012, 15:41. Показов 2464. Ответов 31
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как можно "по-оптимизированнее" проверить, есть ли пользователь с каким-либо именем?
вот что я думаю, но очень сомневаюсь...
SQL
1
SELECT `name` FROM `table` WHERE `name`='$name'
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.10.2012, 15:41
Ответы с готовыми решениями:

Проверка на существовании записи учитывая регистр
Приветствую! Необходимо проверить существует ли запись в бд, учитывая регистр и если такая существует вывести id пользователя. uSer1 и...

Проверка имени
Доброго времени суток. Возникла потребность проверять изменилллось ли имя файла. При это делать нужно только в мэйне Пример: int...

Проверка имени
Всем добрый день! Столкнулся с такой проблемой: в базе данных MySQL в таблице users хранится имя LLM\\asmirnov. Я проверяю есть ли...

31
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:04  [ТС]
Студворк — интернет-сервис помощи студентам
с учётом, что сравниваемое поле находится в 4-ом столбце

Добавлено через 2 минуты
проще говоря, проверка. существует ли уже такой логин в бд? я знаю как сделать, но думаю, что есть способы более оптимизированные.
0
1178 / 1128 / 94
Регистрация: 31.05.2012
Сообщений: 3,060
16.10.2012, 23:09
Да какая разница в каком столбце. mysql_result выбирает из результата.
запрос
SQL
1
SELECT COUNT(1) FROM ...
сколько столбцов вернёт? 1? не потому что там цифра 1, а потому что выбирается
SQL
1
SELECT ЧТО_ТО FROM
вот это ЧТО_ТО - 1 поле всего.
нумерация с 0.
значит
PHP
1
mysql_result($res, 0);
Ну а если не нарвится, можно так
Задайте псевдоним полю.
PHP
1
2
3
$sql = "SELECT COUNT(1) AS `count` FROM `table` WHERE `name`='$name'";
$row = mysql_fetch_assoc($res);
$exists = (bool)$row['count'];
Можно сократить так
PHP
1
2
$sql = "SELECT COUNT(1) AS `count` FROM `table` WHERE `name`='$name'";
$exists = (bool)end(mysql_fetch_assoc($res));
end - выбирает последнее значение из массива, у вас оно всего 1.

Добавлено через 1 минуту
Цитата Сообщение от ProstoMad Посмотреть сообщение
проще говоря, проверка. существует ли уже такой логин в бд? я знаю как сделать, но думаю, что есть способы более оптимизированные.
то етсь более оптимизированный чем
SQL
1
SELECT COUNT(1) FROM `table` WHERE `name` = '$name'
?
Ну поищите
0
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:15  [ТС]
вот я и пытаюсь разобраться что такое count(1) =)
т.е. count(1) не будет искать более 1-го совпадения, или будет искать из второго столбца?

Добавлено через 19 секунд
или я опять не доганяю?)
0
1178 / 1128 / 94
Регистрация: 31.05.2012
Сообщений: 3,060
16.10.2012, 23:16
Я же расписал тут всё https://www.cyberforum.ru/post3569727.html
0
16.10.2012, 23:20

Не по теме:

Цитата Сообщение от DrobyshevAlex Посмотреть сообщение
count(1)
насколько я помню, оно тоже не посчитает NULL-поля. Причем, вообще, вся эта разница по скорости сколько я не гуглил (у меня таблицы большой нет) в одну милисекунду (на большой объем данных, сколько - забыл), к тому же почти везде пишут что на ORACLE это распространенный обман и быстрее и лучше запрос с подстановкой *.. Спор устраивать не хочу, лишь высказал свое мнение, для себя можете посмотреть, если интересно:
искал по запросу "count(*) или count(1)" и "SELECT count(*) или count(1)", возможно я и неправ :)

0
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:25  [ТС]
1 в count() просто 1.
не понял.
можно тогда на примере? таблица table в ней 5 столбцов. 1."id", 2."name", 3. "pass", 4. "email", 5. "date".
Мне нужно, что бы проверялась почта($email) на совпадение. count("email") не подходит, т.к. где-то читал, что она дольше выполняется. Как ещё с count() можно проверить?
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
16.10.2012, 23:26
не в count подставлять надо, а в условие WHERE
0
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:30  [ТС]
чем будyт отличаться count(1) от count(2) и count(0)?
0
1178 / 1128 / 94
Регистрация: 31.05.2012
Сообщений: 3,060
16.10.2012, 23:35
Цитата Сообщение от KOPOJI Посмотреть сообщение
насколько я помню, оно тоже не посчитает NULL-поля.
Что значит не посчитает нулл поля? Как 1 может быть равно нулл?

Цитата Сообщение от KOPOJI Посмотреть сообщение
что на ORACLE
здесь разговор про араклу?) я это прочитал в блоге программиста с mysql, который занимается именно вопросом быстродействия


Цитата Сообщение от ProstoMad Посмотреть сообщение
Как ещё с count() можно проверить?
Вам ещё рах написать?
SQL
1
COUNT(1)
1 - это просто число!

аналог на пхп грубо говоря:
PHP
1
2
3
4
5
6
function count($data)
{
    static $a = 0;
    $a += $data == true ? 1 : 0;
    return $a;
}
Передаёте туда имя поля, вы получите что поле будет выбрано из таблицы, проверенно не null нулл ли оно, если не нулл, то значение счётчика будет увеличено на 1.

теперь передайте туда 1, вместо имени поля, проверка пройдёт? пройдёт всегда.

Добавлено через 1 минуту
Цитата Сообщение от ProstoMad Посмотреть сообщение
чем будyт отличаться count(1) от count(2) и count(0)?
не чем
может быть count(null) - это не когда не вернёт увеличение счётчика.
и может быть всё кроме null! это всегда увеличт счётчик.
но лучше юзать число, так как скорость проверки будет быстрей на сколько я знаю.
0
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:42  [ТС]
похоже я перепутал с mysql_result() второй арнумент, это номер столбца? где первый столбец с номером 0?
0
1178 / 1128 / 94
Регистрация: 31.05.2012
Сообщений: 3,060
16.10.2012, 23:44
Это номер не столбца таблицы!
Это номер столбца в результате запроса
1
50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191
16.10.2012, 23:45  [ТС]
всё, кажется понял) спасбо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.10.2012, 23:45
Помогаю со студенческими работами здесь

Проверка имени
Здравствуйте при вводе имени вступает строка кода на пхп if (preg_match ("|/^\+|i", $_POST) || $lens<3) ...

Проверка имени
подскажите пожалуйста, как мне проверить правильность цифр, то есть я изначально задумал число как пароль, к примеру 123, а если мы вводим...

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

Проверка имени процесса
Здравствуйте, у меня есть код: public static boolean checkProcesses(String onlineData) { if (onlineData == null) return...

Проверка имени и фамилии
Здравствуйте, помогите пожалуйста составить регулярное выражение, могут быть только или английские или русские(символы в том числе и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
32
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru