50 / 40 / 5
Регистрация: 30.06.2010
Сообщений: 1,191

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

16.10.2012, 15:41. Показов 2531. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru