Премини към съдържанието
  • Добре дошли!

    Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

    Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

     

Java Sql queries


Препоръчан отговор

Здравейте искам да попитам за съвет как да стигна до решение на моя проблем. Благодаря предварително

 

Значи проблема ми е следния искам да мога да добавям няколко едни и същи реда със различно име като ползвам split 

1685894511_.png.28cc52a92a316e17eaa3ea222918dd17.png

във снимката която съм прикачил със програмката ми искам при модел да мога да ползвам пример: sony_ver1;sony_ver2;sony_ver3 и тн.

обаче какво ли не пробвах не мога да стигна до решение как да внедра тъпия split

		btnNewButton_1.setBounds(220, 35, 89, 23);
		contentPanel.add(btnNewButton_1);
		{
			JPanel buttonPane = new JPanel();
			buttonPane.setLayout(new FlowLayout(FlowLayout.RIGHT));
			getContentPane().add(buttonPane, BorderLayout.SOUTH);
			{
				JButton okButton = new JButton("Добре");
				okButton.addActionListener(new ActionListener()
				{
					@Override
					public void actionPerformed(ActionEvent e)
					{
						try
						{
							ComboBoxData selecteditem = (ComboBoxData) comboBox.getSelectedItem();
							Connection conn = Database.getConnection();
							PreparedStatement pst1 = conn.prepareStatement("select max(scatid)+1 from subcategory");
							ResultSet rs = pst1.executeQuery();
							String cat_id = "";
							while (rs.next())
							{
								cat_id = rs.getString(1);
							}
							// the mysql insert statement
							String query = " insert into subcategory (scatid, catid, scatname, path)" + " values (?, ?, ?, ?)";
							
							// create the mysql insert preparedstatement
							PreparedStatement preparedStmt = conn.prepareStatement(query);
							preparedStmt.setString(1, cat_id.toString());
							preparedStmt.setString(2, String.valueOf(selecteditem.getId()));
							preparedStmt.setString(3, model.getText());
							preparedStmt.setString(4, ime.getText());
							
							// execute the preparedstatement
							preparedStmt.execute();
							
							conn.close();
						}
						catch (Exception ex)
						{
							JOptionPane.showConfirmDialog(null, "Голема Грешка:" + ex.getMessage() + " ", "Грешка", JOptionPane.ERROR_MESSAGE, 1);
						}
						Object[] options =
						{
							"Добре"
						};
						int input = JOptionPane.showOptionDialog(null, "Успешно добавено раководство.", "Успех", JOptionPane.PLAIN_MESSAGE, JOptionPane.INFORMATION_MESSAGE, null, options, options[0]);
						if (input == JOptionPane.YES_OPTION)
						{
							dispose();
							List<File> files = new ArrayList<>();
							files.add(fileToSave);
							for (File file : files)
							{
								try
								{
									Files.copy(file.toPath(), (new File(path + file.getName())).toPath(), StandardCopyOption.REPLACE_EXISTING);
								}
								catch (IOException e1)
								{
									JOptionPane.showConfirmDialog(null, "Голема Грешка:" + e1.getMessage() + " ", "Грешка", JOptionPane.ERROR_MESSAGE, 1);
									e1.printStackTrace();
								}
							}
						}
						
					}
				});
				okButton.setActionCommand("OK");
				buttonPane.add(okButton);
				getRootPane().setDefaultButton(okButton);
			}
			{
				JButton cancelButton = new JButton("Отказ");
				cancelButton.addActionListener(new ActionListener()
				{
					@Override
					public void actionPerformed(ActionEvent e)
					{
						dispose();
					}
				});
				cancelButton.setActionCommand("Cancel");
				buttonPane.add(cancelButton);
			}
		}
	}
}

идеята е че един pdf отговаря за 5 до 10 различни модела техника и добавянето на всеки по отделно би било голяма мъка при един и същи файл трябва да пишеш едно и също нещо  което е досадно :)

И искрено Благодаря за помоща във предната тема на mr mcwolf

Благодаря за отделеното време :)

Линк към коментара
Сподели в други сайтове

преди 1 час, Raze написа:

Не разбрах точно къде искаш да ползваш split, за кой стринг? В този код има само да добавяш записи към таблицата.

 

Идеята ми е чрез split да мога да добавя записи със различни имена 

Защото във момента при добавяне на запис добавя само един ред със инфо id/name/path в случея името на файла който трябва да отвори а аз искам при вавеждането на името чрез split да направя един и същи запис със различно име както ще са ваведени пример Модел: test-model1;test-model2;test-model

Линк към коментара
Сподели в други сайтове

Например така:

// буферни променливи
String str1, str2, str3, str4;
String[] astr3split;

// въвежда полетата
str1 = cat_id.toString());
str2 = String.valueOf(selecteditem.getId()));
str3 = model.getText());
str4 = ime.getText());

// разделя в масив имената
astr3split = str3.split(";");  

// прави отделни заявки за всяко име от масива
for(int i=0; i<astr3split.length; i++)
{
  // the mysql insert statement
  String query = " insert into subcategory (scatid, catid, scatname, path)" + " values (?, ?, ?, ?)";
                            
  // create the mysql insert preparedstatement
  PreparedStatement preparedStmt = conn.prepareStatement(query);
  preparedStmt.setString(1, str1);
  preparedStmt.setString(2, str2);
  preparedStmt.setString(3, astr3split);
  preparedStmt.setString(4, str4);
                            
  // execute the preparedstatement
  preparedStmt.execute();
  conn.close();
}

 

Поправка:

 preparedStmt.setString(3, astr3split);

тук astr3split трябва да има индекс i 

 

Линк към коментара
Сподели в други сайтове

преди 6 часа, NVJ написа:

Например така:

// буферни променливи
String str1, str2, str3, str4;
String[] astr3split;

// въвежда полетата
str1 = cat_id.toString());
str2 = String.valueOf(selecteditem.getId()));
str3 = model.getText());
str4 = ime.getText());

// разделя в масив имената
astr3split = str3.split(";");  

// прави отделни заявки за всяко име от масива
for(int i=0; i<astr3split.length; i++)
{
  // the mysql insert statement
  String query = " insert into subcategory (scatid, catid, scatname, path)" + " values (?, ?, ?, ?)";
                            
  // create the mysql insert preparedstatement
  PreparedStatement preparedStmt = conn.prepareStatement(query);
  preparedStmt.setString(1, str1);
  preparedStmt.setString(2, str2);
  preparedStmt.setString(3, astr3split);
  preparedStmt.setString(4, str4);
                            
  // execute the preparedstatement
  preparedStmt.execute();
  conn.close();
}

 

Поправка:

 preparedStmt.setString(3, astr3split);

тук astr3split трябва да има индекс i 

 

Благодаря за примера :) заемам се ✌️

Линк към коментара
Сподели в други сайтове

Добавете отговор

Можете да публикувате отговор сега и да се регистрирате по-късно. Ако имате регистрация, влезте в профила си за да публикувате от него.

Гост
Напишете отговор в тази тема...

×   Вмъкнахте текст, който съдържа форматиране.   Премахни форматирането на текста

  Разрешени са само 75 емотикони.

×   Съдържанието от линка беше вградено автоматично.   Премахни съдържанието и покажи само линк

×   Съдържанието, което сте написали преди беше възстановено..   Изтрий всичко

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Добави ново...

Информация

Поставихме бисквитки на устройството ви за най-добро потребителско изживяване. Можете да промените настройките си за бисквитки, или в противен случай приемаме, че сте съгласни с нашите Условия за ползване