Модераторы: LSD

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> поиск по базе 
V
    Опции темы
kostay
Дата 30.5.2007, 01:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



кто нибудь может обьеснить как искать в базе набор символов которые задоются (4асть слова кпримеру) 
сам принцып каков?
если перебрать каждую строку, и как? а найти в етой строке набор нужных символов как?
если не трудно то пару примеров былоб неплохо или ссылок на похожее, 4тото ни4его не найду
PM MAIL   Вверх
nornad
Дата 30.5.2007, 03:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1079
Регистрация: 16.2.2007
Где: в Караганде

Репутация: нет
Всего: 31



Если SQL, то старый добрый LIKE тебе в помощь:
Код

SELECT * FROM my_table WHERE my_column LIKE '%kostay%';



--------------------
Три достоинства программиста: Леность, Нетерпение и Гордость
Ларри Уолл
PM MAIL WWW ICQ Skype MSN   Вверх
LSD
Дата 30.5.2007, 10:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Самый простой - это оператор LIKE. Некоторые СУБД позволяют использовать регулярные выражения. Еще можно использовать пользовательские функции.

Если база большая то тут уже надо использовать полнотекстовый поиск.

Модератор: перемещено из Java: Общие вопросы.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
kostay
Дата 30.5.2007, 22:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



ешо... 
большие и маленькие буквы роль имеет? мне надо 4тобы не имело....тоесть ишу 'текст' находит Текст и теКст 
и как переменную внести?
PreparedStatement + ? так?
PM MAIL   Вверх
SergeBS
Дата 31.5.2007, 08:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1111
Регистрация: 10.6.2005
Где: Владимир

Репутация: 1
Всего: 22



kostay
А как насчет элементарного знания предмета? Идешь на Компьютерная литература и читаешь Грабера "Понимание SQL". Или в хелпе своего сервака ищешь слово UPPER, UPPERCASE и т.п. Так оно быстрее и лучше выйдет.
PM MAIL   Вверх
batigoal
Дата 31.5.2007, 10:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Цитата(kostay @  30.5.2007,  23:24 Найти цитируемый пост)
большие и маленькие буквы роль имеет? мне надо 4тобы не имело....тоесть ишу 'текст' находит Текст и теКст 

LIKE будет искать в соответствии с регистром твоих букв. Если хочешь этого избежать - делай
Код

SELECT * FROM my_table WHERE UPPER(my_column) LIKE '%SEARCH LINE%'; 

Цитата(kostay @  30.5.2007,  23:24 Найти цитируемый пост)
PreparedStatement + ? так? 

Да, можно и так.


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
kostay
Дата 5.6.2007, 01:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



на любой поск мне принтуется null
и как к ? присоба4ить %%

база access, s[i] размер 10
searchline тоже переведина в uppercase 
вобшем надо 4тобы с[и] заполнился результатами поиска

Код

try {
                ps = connection.prepareStatement(
                        "SELECT pvm FROM calendar WHERE UCASE(notes) = ? ORDER BY pvm");
                ps.setString(1,searchline);
                result = ps.executeQuery();
                ps = null;

                while (result.next()) {
                    for(int i=0; i< s.length; i++){
                        
                        s[i] = result.getString("pvm");
                        System.out.println(s[i]);

                    }
                }

PM MAIL   Вверх
LSD
Дата 5.6.2007, 07:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Чему у тебя равно searchline?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
batigoal
Дата 5.6.2007, 11:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Цитата(kostay @  5.6.2007,  02:00 Найти цитируемый пост)
и как к ? присоба4ить %%

Как обычные символы.


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
kostay
Дата 5.6.2007, 11:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



searchline = ТЕКС, етот текс то4но есть в базе, при вставке в функцию делаю uppercase

Код

ps.setString(1,"%"+searchline+"%");

так не помогает
PM MAIL   Вверх
LSD
Дата 5.6.2007, 12:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Текст который ты ищешь в русской кодировке?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
kostay
Дата 5.6.2007, 12:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



searchline = jTextField.getText().toUpperCase()

ишу loma в базе есть слово Loma, в поле notes среди текста, мне в с[и] надо записать все даты из pvm столбца ну сколько влезет

может тут 4о не так?
Код

private PreparedStatement ps;
private ResultSet result;


Это сообщение отредактировал(а) kostay - 5.6.2007, 12:35
PM MAIL   Вверх
batigoal
Дата 5.6.2007, 18:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 1
Всего: 151



Цитата(kostay @  5.6.2007,  02:00 Найти цитируемый пост)
WHERE UCASE(notes) = ?

Должно быть
Код

WHERE UCASE(notes) LIKE ?



--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
kostay
Дата 5.6.2007, 19:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



Цитата(batigoal @ 5.6.2007,  18:17)
Цитата(kostay @  5.6.2007,  02:00 Найти цитируемый пост)
WHERE UCASE(notes) = ?

Должно быть
Код

WHERE UCASE(notes) LIKE ?

пробовал, но тогда java.sql.SQLException: No data found
и ку4а других ошибок опять ишу loma в базе есть Loma 

пишет 4то, одна из ошибок гдето тут s[i] = result.getString("pvm");

PM MAIL   Вверх
kostay
Дата 6.6.2007, 01:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 205
Регистрация: 16.5.2007

Репутация: нет
Всего: нет



удалил фор, терь всё принтует нармально и 4отко... странно

поменял код сделал вот так, снова ошибки.. как мне результат то в стринг засунуть
Код

                while (result.next()) {
                    
                    s[0] = result.getString("pvm"); // bez etoj stroki vsjo ok
                        System.out.println(result.getString("pvm"));
                    
                }


и так:

Код

        try {
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
            connection = DriverManager.getConnection("jdbc:odbc:calendar");
            statement = connection.createStatement();
            
            resultset = statement.executeQuery("SELECT pvm FROM calendar WHERE UCASE(notes) LIKE '%" + searchline + "%'");
            
            while (resultset.next()) {
                System.out.println(resultset.getString(1));
                field = resultset.getString("pvm");// bez etoj stroki vsjo ok
            }
            statement.close();
            connection.close();
        }


Это сообщение отредактировал(а) kostay - 6.6.2007, 02:11
PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0994 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.