Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/46: Рейтинг темы: голосов - 46, средняя оценка - 4.87
0 / 0 / 0
Регистрация: 13.05.2012
Сообщений: 50

Добавление записей в таблицу БД MySql

16.05.2013, 18:39. Показов 9248. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не пойму почему не работает добавление записей в БД. Вот код метода:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
    public void insert(String id1, String id2, String id3, String id4, String id5, String id6) {
        try {
            String sql = "";
            conn.prepareStatement(sql);
 
 
            sql = "INSERT INTO `hotel_room`"
                    + "(`id`, `Назва`, `Місця`, `Тип`, `Ціна номера`, `Ціна за місце`)"
                    + "VALUES ('" + id1 + "', '" + id2 + "', '" + id3 + "', '" + id4 + "', '" + id5 + "', '" + id6 + "')";
 
            PreparedStatement X=(PreparedStatement) conn.prepareStatement(sql);
            X.execute();
 
        } catch (Exception e) {
            System.out.println("Помилка");
        }
    }
Java
1
2
3
4
5
6
7
8
9
10
11
    private void addRoomActionPerformed(java.awt.event.ActionEvent evt) {                                        
      
 
        
        hotelMySql con = new hotelMySql();
        
 
        con.insert(txtR1.getText(), txtR2.getText(), txtR3.getText(),
                txtR4.getText(), txtR5.getText(), txtR6.getText());
 
    }
Срочно нужна помощь.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.05.2013, 18:39
Ответы с готовыми решениями:

Добавление записей в таблицу и связанную с ней таблицу, с учётом связи
Имеются 3 таблицы: кабинет id_cab n_cab устройства ...

Добавление записей в таблицу
Есть форма2 на которой мы выбираем группу учащихся в комбобоксе. По нажатию на кнопку нужно реализовать: -Создать таблицу с именем...

Добавление записей в таблицу
Как при нажатии на кнопку добавить 10 любых записей в таблицу и при нажатии на другую кнопку удалить вторую запись?

5
 Аватар для AckiyBolt
653 / 402 / 35
Регистрация: 19.02.2013
Сообщений: 1,072
Записей в блоге: 2
16.05.2013, 19:32
во-первых, вы не правильно работаете с PreparedStatement. читайте это.
во-вторых, вы будете вечность гореть в аду за пробелы в названиях колонок
в-третьих, вас там будут подвергать самым изощренным пыткам за то, что эти названия кириллические
2
0 / 0 / 0
Регистрация: 13.05.2012
Сообщений: 50
16.05.2013, 21:20  [ТС]
Да я в этом не пойму ниче.(я новичек в яве). Может подскажете как правильно работать с PreparedStatement?. Мне нужно чтобы по щелчку по кнопке оно добавляло записи в таблицу MySql и сразу обновляло.

Добавлено через 1 час 10 минут
пробовал так всеравно не пашет.
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
    private void addRoomActionPerformed(java.awt.event.ActionEvent evt) {                                        
        hotelMySql con1 = new hotelMySql();
        
        String id1 = txtR1.getText(),id2 = txtR2.getText(), id3 = txtR3.getText(),
                id4  = txtR4.getText(),id5 = txtR5.getText(),id6 = txtR6.getText();
        
        
        String sql = "";
        try{
            
            sql ="INSERT INTO hotel_room (id,Назва,Місця,Тип,Ціна номера,"
                    + "Ціна за місце) VALUES(" + con1.quotate(id1) + "," + con1.quotate(id2) + "," + 
                    con1.quotate(id3) + "," + 
                    con1.quotate(id4) + "," + 
                    con1.quotate(id5) + "," + 
                    con1.quotate(id6) + ","+")";
            
            Statement X = (Statement) con1.getConn().createStatement();
            int done = X.executeUpdate(sql);
            initComponents();
 
            
            
        }catch(Exception e){
            System.out.println("Помилка");
        }
        
 
      
    }
Java
1
2
3
4
    public String quotate(String content){
    
        return "'"+content+"'";
    }
0
0 / 0 / 0
Регистрация: 15.04.2014
Сообщений: 5
09.09.2014, 15:08
в VALUES каждое добавляемое значение попробуйте еще в одиночные кавычки взять и после каждой запятой еще пробелы добавить.
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
09.09.2014, 15:36
igor2265, во-первых, какая ошибка то?

Во-вторых, перечитайте http://docs.oracle.com/javase/... pared.html Там даже с примерами.
Главное - никогда не составляйте запрос конкатенацией со значениями.
0
0 / 0 / 1
Регистрация: 01.04.2012
Сообщений: 9
15.09.2014, 21:19
приветствую. Используй драйвер для решения проблемы org.gjt.mm.mysql.Driver. Без него ничего не сделаешь. Вот тебе рабочий код. Внешние переменные сам засунь и будет все работать. Надеюсь помог

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
public static void main(String[] args) throws InstantiationException, IllegalAccessException, ClassNotFoundException, SQLException{
        
        createBase();
        openBase();
    } // Главная функция
 
 
public static void createBase() throws InstantiationException, IllegalAccessException, ClassNotFoundException{
        Class.forName("org.gjt.mm.mysql.Driver").newInstance();
        
         String url = "jdbc:mysql://localhost:3306/ИМЯБАЗЫ";                      //вместо локалхост свой путь к базе
         System.out.println("Connect to driver");
         String createAccounts;
         createAccounts = "create table StudentU (faculty VARCHAR(6), groupName VARCHAR(20), name VARCHAR(20), age INTEGER, specif VARCHAR(50), lessons VARCHAR(20))"; // СОЗДАНИЕ ПОЛЕЙ (СТОЛБЦЫ)
         
         try{ 
             
         Connection con = DriverManager.getConnection(url, "ИМЯБАЗЫ","ПАРОЛЬ"); 
         Statement stmt  = con.createStatement();
         
         
         stmt.executeUpdate(createAccounts);
         
         stmt.executeUpdate("INSERT INTO StudentU VALUES ('FIT', 'CM-14',   'Ovsyanikov V.V.', '21', 'good student', 'math' )");
         stmt.executeUpdate("INSERT INTO StudentU VALUES ('KND', 'RT-14',   'Boyko S.V.',      '22', 'bad student',  'eanglish' )");
         stmt.executeUpdate("INSERT INTO StudentU VALUES ('ATT', 'ZW-14',   'Glushko I.O.',    '20', 'good student', 'electrodin' )");
         stmt.executeUpdate("INSERT INTO StudentU VALUES ('FIT', 'CMM-14',  'Bezrukov T.V.',   '21', 'very bad',     'math' )");
    
        
        
         
         
         System.out.println("Table created");
         
        
         stmt.close();
         con.close();
         
         }catch(SQLException e){ 
             
             System.out.println(e.getMessage());
         }  
    }
 
 
 
  public static void openBase() throws SQLException{
        
        Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/ИМЯБАЗЫ", "ИМЯБАЗЫ","ПАРОЛЬ"); 
         Statement stmt  = con.createStatement();
        
         String query = "SELECT faculty, groupName, name, age, specif, lessons  FROM StudentU";
            ResultSet rs = stmt.executeQuery(query);
            while (rs.next()) {
                String f = rs.getString("faculty");
                String g = rs.getString("groupName");
                String n = rs.getString("name");
                int    a = rs.getInt("age");
                String s = rs.getString("specif");
                String l = rs.getString("lessons");
                
            
                System.out.println(f + " " + g + " " + n + " " + a + " " + s+ " " + l);
            }
            
            stmt.close();
             con.close();
 
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.09.2014, 21:19
Помогаю со студенческими работами здесь

Добавление записей в таблицу
Здравствуйте! Подскажите: как добавить записи в таблицу 1, если из таблицы 2 надо взять только несколько полей. В таблице 1 есть:...

Добавление записей в таблицу
Как при помощи компонента Table добавлять записи в Табличку, если все значения полей для добавления вводятся в компонент Edit? ...

Добавление записей в таблицу
Здравствуйте, не знал куда обратиться(в раздел php или js'a), т.к новичок в вебе. Суть проблемы такова: На странице есть таблица с...

Добавление записей в таблицу с 1:M
Есть таблица debtors 1 и M payments, на странице выводится список должников (debtors) по клику на которые, я должен добавлять в таблицу...

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru