Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
1 / 1 / 1
Регистрация: 20.07.2014
Сообщений: 21

Небольшая база данных в java

11.08.2016, 14:48. Показов 753. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
подскажите пожалуйста с кодом реализации. Итак предположим у нас есть два человека. У этих людей имя фамилия и адрес. Нужно сделать поиск по имени например. то есть если обоих людей зовут Иван и в поиске мы вводим Иван то вывести должно имя фамилию и адрес обоих людей.

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import java.util.ArrayList;
import java.util.List;
 
 
public class Task123 {
    public static void main(String[] args) {
        Database employee1 = new Database("Арнольд", "Столов", "Дорожная, 1");
        Database employee2 = new Database("Константин", "Васильев", "Теплый стан, 23");
        //далее будет реализация методов класса
    }
}
class Database{
    private List<String> fullName = new ArrayList<>();
    private List<String> name = new ArrayList<>();
    private List<String> surname = new ArrayList<>();
    private List<String> address = new ArrayList<>();
 
    Database(String name, String surname, String address){
        fullName.add(name + surname);
        this.name.add(name);
        this.surname.add(surname);
        this.address.add(address);
 
    }
    List<String> searchByName(String search){
        List<String> result = new ArrayList<>();
        //реализация поиска
        int count = 0 ;
        for (int i = 0; i < fullName.size(); i++) {//берем наш лист с полным именем
            //этим двум переменным мы присваиваем первыю часть имени и фамилии, 
            //то есть при вводе в поиск "иван" должно выдавать человека с фамилией Иванов том числе
            String bufName = name.get(i).substring(0, search.length()-1);    
            String bufSurname = surname.get(i).substring(0, search.length()-1);
            //о соотвественно сравниваем наши первые части с поиском игнорируя регистр
            if (bufName.equalsIgnoreCase(search) || bufSurname.equalsIgnoreCase(search)){
                result.add(count++,fullName.get(i)  + address.get(i));
            }
        }
        return result;
    }
}

В методе поиска у меня вопросов нет. Вопрос вот в чем. При вызове конструктора внутри мэйн мы передаем наши данные классу database. После этого данные отправляются в соотвествующие листы(list) для реализации непосредственного поиска по всем элементам листа. Как потом вызвать метод поиска из мэйна чтобы он выполнил по все сотрдникам. Логично что если я вызову его к примеру employee1.searchByName("Иван"){...} то выдаст он мне только если у этого человека есть где либо в имени или фамилии слово Иван. Как реализовать этот поиск по всем работникам

Добавлено через 18 минут
и я прекрасно понимаю, что данная реализация неправильна и более чем убога
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.08.2016, 14:48
Ответы с готовыми решениями:

Java и локальная база данных
Есть возможность включить в jar файл локальную базу данных? Что это за базы? Чтобы вообщем без сервера.

Java база данных
кто может объяснить как использовать базу данных sql в программе на языке Java, какие программы и драйвера нужно поставить?

База данных на Java
Я плохо разбираюсь в базах данных,так что прошу Вас помочь мне.Мне надо создать базу данных через JDBC-ODBC. вот так я подключаю драйвер...

5
 Аватар для reisal78
944 / 687 / 230
Регистрация: 28.04.2013
Сообщений: 1,925
11.08.2016, 15:00
evgeniybal,

небольшая подсказка =)

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
public class Employee {
    private String name;
    private String surname;
    private String address;
 
    public Employee(String name, String surname, String address) {
        this.name = name;
        this.surname = surname;
        this.address = address;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getSurname() {
        return surname;
    }
 
    public void setSurname(String surname) {
        this.surname = surname;
    }
 
    public String getAddress() {
        return address;
    }
 
    public void setAddress(String address) {
        this.address = address;
    }
}
Java
1
List<Employee> employees = new ArrayList<>();

Java
1
2
3
4
5
6
public interface EmployeeRepository {
    List<Employee> findByName(String name);
    List<Employee> findAll();
    void delete(Employee employee);
    void add(Employee employee);
}
1
1 / 1 / 1
Регистрация: 20.07.2014
Сообщений: 21
11.08.2016, 15:26  [ТС]
Цитата Сообщение от reisal78 Посмотреть сообщение
List<Employee> employees = new ArrayList<>();
Это как я понимаю должно быть в класса Database.


я не могу понять вот что. Для поиска по имени, в теории, в классе database в соответствующем методе, которому я передаю строку поиска, я ищу в каждом поле каждого работника совпадение имени. Когда нахожу, то строку с именем фамилией и адресом помещаю в созданный лист) потом просто возвращаю лист. Я не могу понять как мне обратиться отдельно к имени каждого работника
0
 Аватар для reisal78
944 / 687 / 230
Регистрация: 28.04.2013
Сообщений: 1,925
11.08.2016, 15:33
Цитата Сообщение от evgeniybal Посмотреть сообщение
Я не могу понять как мне обратиться отдельно к имени каждого работника
ну например так:

Java
1
2
3
4
5
6
7
8
9
10
   @Override
    public List<Employee> findByName(String name) {
        List<Employee> result = new ArrayList<>();
        for (Employee employee : employees) {
            if (employee.getName().equals(name)) {
                result.add(employee);
            }
        }
        return result;
    }
0
1 / 1 / 1
Регистрация: 20.07.2014
Сообщений: 21
11.08.2016, 16:15  [ТС]
Если не затруднит сможете скинуть код целиком ибо с листами и коллекцией познакомился только сегодня и пока что в них еще не разобрался
0
 Аватар для reisal78
944 / 687 / 230
Регистрация: 28.04.2013
Сообщений: 1,925
11.08.2016, 16:29
evgeniybal,

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import java.util.ArrayList;
import java.util.List;
 
public class DemoApp {
    public static void main(String[] args) {
 
        //Инициализация и сохдание хранимых данных
        EmployeeRepository employeeRepository = new EmployeeRepositoryImpl();
 
        Employee e1 = new Employee("Иван", "Баранов", "Адрес #1");
        Employee e2 = new Employee("Иван", "Петров", "Адрес #2");
        Employee e3 = new Employee("Максим", "Горький", "Адрес #3");
        Employee e4 = new Employee("Федор", "Иванов", "Адрес #4");
 
        //Сохраняем в хранилище
        employeeRepository.add(e1);
        employeeRepository.add(e2);
        employeeRepository.add(e3);
        employeeRepository.add(e4);
 
        //Демонстрация
        List<Employee> result = employeeRepository.findByName("Иван");
 
        //Вывод результата
        for (Employee employee :result) {
            System.out.println(employee);
        }
 
    }
}
 
interface EmployeeRepository{
    List<Employee> findByName(String name);
    List<Employee> findAll();
    void delete(Employee employee);
    void add(Employee employee);
}
 
class EmployeeRepositoryImpl implements EmployeeRepository {
    private List<Employee> employees = new ArrayList<>();
 
    @Override
    public List<Employee> findByName(String name) {
        List<Employee> result = new ArrayList<>();
        for (Employee employee : employees) {
            if (employee.getName().equals(name)) {
                result.add(employee);
            }
        }
        return result;
    }
 
    @Override
    public List<Employee> findAll() {
        // TODO: 11.08.2016 не реализованно
        return null;
    }
 
    @Override
    public void delete(Employee employee) {
        // TODO: 11.08.2016 не реализованно
    }
 
    @Override
    public void add(Employee employee) {
        employees.add(employee);
    }
}
 
class Employee {
    private String name;
    private String surname;
    private String address;
 
    public Employee(String name, String surname, String address) {
        this.name = name;
        this.surname = surname;
        this.address = address;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getSurname() {
        return surname;
    }
 
    public void setSurname(String surname) {
        this.surname = surname;
    }
 
    public String getAddress() {
        return address;
    }
 
    public void setAddress(String address) {
        this.address = address;
    }
 
    @Override
    public String toString() {
        return "Employee{" +
                "name='" + name + '\'' +
                ", surname='" + surname + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.08.2016, 16:29
Помогаю со студенческими работами здесь

База данных и JAVA?
У меня главный вопрос , где скачать этот драйвер , на сайте у Сан есть несколько драйверов но к ним нет примеров, раньше у меня стоял...

База данных InterBase и Java
Надо подконнектиться к InterBase 6.5 c помощью Java. Написал следующее: import java.*; import java.sql.*; public class dbaccess...

Java, ApachePOI и база данных
У меня есть проект, работающий с базой данных. Данные импортируются из таблицы EXCEL и анализируются с помощью запросов как в базе данных....

Небольшая База Данных...
Ввести и сохранить в файле данные след. структуры: Ф.И.О. студента, номер группы, результат сдачи сессии (5 экзаменов). Организовать...

Небольшая база данных
Доброго времени суток, всем) Пишу вам с просьбой помочь. Мне удалос написать рабочий код программы по таким вот услловиям: Необходимо...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru