0 / 0 / 1
Регистрация: 02.08.2016
Сообщений: 9
MySQL

Добавление в связующую таблицу (many to many) через JDBC?

28.03.2018, 13:52. Показов 5519. Ответов 1
Метки jd, jdbc (Все метки)

Студворк — интернет-сервис помощи студентам
Есть бд, в ней 2 сущности и связь many to many, создаю DAO для crud операций, далее возникает вопрос, я хочу создать developer и добавить ему skill. Как мне добавить данные в таблицу skills_developers. Не создавая доп. класс skills_developers
MySQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*Create table developers*/
 
CREATE TABLE developers (
  id   INT          NOT NULL PRIMARY KEY,
  name VARCHAR(100) NOT NULL
  salary VARCHAR(100) NOT NULL
);
 
/*Create table skills*/
 
CREATE TABLE skills (
  id   INT          NOT NULL PRIMARY KEY,
  name VARCHAR(100) NOT NULL
);
 
/*Create table skill_developers with links*/
 
CREATE TABLE skills_developers (
  dev_id    INT NOT NULL,
  sk_id     INT NOT NULL,
  FOREIGN KEY (dev_id) REFERENCES developers (id),
  FOREIGN KEY (sk_id) REFERENCES skills (id)
);
Я так понимаю необходимо создать developer
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
public void create(Developer developer) {
        String sql1 = "INSERT INTO developers VALUES (?,?,?)";
        Connection connection = ApplicationJDBC.getConnection();
        try {
            PreparedStatement preparedStatement = connection.prepareStatement(sql1);
            preparedStatement.setLong(1, developer.getId());
            preparedStatement.setString(2, developer.getFullName());
            preparedStatement.setLong(3, developer.getSalary());
 
            preparedStatement.execute();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                connection.close();
                System.out.println("Connection is closed!");
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
Сущность Developer
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
public class Developer {
 
    private long id;
    private String fullName;
    private int salary;
    private Set<Skill> skills;
 
    public Developer() {
    }
 
    public Developer(long id, String fullName, int salary) {
        this.id = id;
        this.fullName = fullName;
        this.salary = salary;
    }
 
    public long getId() {
        return id;
    }
 
    public void setId(long id) {
        this.id = id;
    }
 
    public String getFullName() {
        return fullName;
    }
 
    public void setFullName(String fullName) {
        this.fullName = fullName;
    }
 
    public int getSalary() {
        return salary;
    }
 
    public void setSalary(int salary) {
        this.salary = salary;
    }
 
    public Set<Skill> getSkills() {
        return skills;
    }
 
    public void setSkills(Set<Skill> skills) {
        this.skills = skills;
    }
 
    @Override
    public String toString() {
        return "Developer{" +
                "id=" + id +
                ", fullName='" + fullName + '\'' +
                ", salary=" + salary +
                '}';
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.03.2018, 13:52
Ответы с готовыми решениями:

запросы sql+ выборка из таблиц через связующую таблицу
Приветствую форумчан! Ситуация такая: Имеются таблицы Издания (код_издания,название,жанр,издательство,дата_выпуска), Авторы...

Не дает удалить таблицу с именем схемы через jdbc
Нужно почистить схему &quot;sname&quot; для всех баз на сервере. Подключаюсь к серверу по jdbc. Список БД получаю без проблем, список таблиц у...

Многие ко многим, как правильно создать связующую таблицу
Связь Один ко Многим Есть две таблицы, компании и сотрудники, в одной компании может быть несколько сотрудников, но сотрудник не может...

1
0 / 0 / 1
Регистрация: 02.08.2016
Сообщений: 9
30.03.2018, 14:51  [ТС]
Разобрался
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public void addDevSkills(long dev_name, long sk_name) {
        String sql = "INSERT  INTO developer_skills (dev_id, sk_id) " +
                "SELECT d.id, s.id " +
                "FROM developers d, skills s " +
                "WHERE d.id = ? " +
                "AND s.id = ?";
        try (Connection connection = ApplicationJDBC.getConnection()) {
            PreparedStatement preparedStatement = connection.prepareStatement(sql);
            preparedStatement.setLong(1, dev_name);
            preparedStatement.setLong(2, sk_name);
            int rowsAdded = preparedStatement.executeUpdate();
            if (rowsAdded > 0) {
                System.out.println("A skills was added successfully!");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.03.2018, 14:51
Помогаю со студенческими работами здесь

Как автоматически создавать третью (связующую) таблицу при связи многие ко многим ?
Например, есть 3 таблицы Subject , Teacher, Teacher_Subject. Teacher_Subject - связующая таблица, с двумя внешними ключами, без...

При связи многие ко многим можно ли автоматически создавать третью (связующую) таблицу?
Вот 3 таблицы Subject , Teacher, Teacher_Subject. Teacher_Subject - связующая таблица, с двумя внешними ключами. Как сделать так, чтобы...

Добавление поля в таблицу через запрос на добавление
Здравствуйте, подскажите как создать запрос, чтобы к таблице добавить еще одно поле. Поля, не записи. Тип запроса Добавление....

Добавление через Edit в таблицу
Приветствую , необходимо реализовать алгоритм по добавлению данных в таблицу используя Edit для ввода данных. Есть кто может подсказать?

Добавление строк в таблицу через PHP
Приведу пример потом напишу что не могу сделать :) есть таблица most в ней есть nomer и все,как через php добавить в нее к примеру...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru