दिलचस्प पोस्ट
पीएचपी लघु टैग कैसे सक्षम करें? UISlider की अंगूठे की छवि का केंद्र कैसे प्राप्त करें ग्रिड दृश्य छँटाई: क्रमबद्ध दिशा हमेशा बढ़ते जा रहे हैं जावा खींचें और ड्रॉप एचटीएमएल को पीडीएफ़ का उपयोग करके पीडीएफ में परिवर्तित करना? एंड्रॉइड ऑडियोरेकॉर्ड कक्षा – प्रक्रिया लाइव माइक्रो ऑडियो जल्दी, कॉलबैक फ़ंक्शन को सेट अप करें मैं PHP में त्रुटि 404 कैसे बना सकता हूं? एक बड़ी सूची में प्रत्येक एनटी आइटम की सूची वापस करने के लिए पायथनिक तरीका जावा स्विंग में JTextField से मूल्य कैसे प्राप्त करें? कैसे सी + + में एक स्ट्रिंग समय की एक चर संख्या दोहराने के लिए? छवि प्रीलोडर जावास्क्रिप्ट जो इवेंट्स का समर्थन करता है कैसे एक पायथन datetime ऑब्जेक्ट सेकंड के लिए परिवर्तित करने के लिए एआरसी और पुल कास्ट एक्सेलेरोमीटर द्वारा दूरी बढ़ा दी गई मैं जावा में स्ट्रिंग कैसे पैड कर सकता हूं?

JavaFX MySQL कनेक्शन उदाहरण कृपया

क्या कोई मुझे एक वर्ग का एक उदाहरण देता है जो जावाएक्सएक्स को MySQL के साथ जोड़ता है, न मुख्य वर्ग को एक है, केवल एक वर्ग का एक उदाहरण चाहिए जो किसी भी अनुप्रयोग को MySQL डाटाबेस से जोड़ता है और उस डेटाबेस से एक तालिका में एक पंक्ति प्राप्त करता है, खोजी गई पूरे इंटरनेट और मुझे सीधे कुछ भी नहीं मिला, मुझे कुछ भी नहीं चाहिए, काम को पाने के लिए कुछ और करना चाहिए, कृपया। कुछ साफ और सरल

वेब के समाधान से एकत्रित समाधान "JavaFX MySQL कनेक्शन उदाहरण कृपया"

कम से कम, आपको तीन वर्गों की आवश्यकता होती है: एक आपके डेटा का प्रतिनिधित्व करने के लिए, आपके यूआई के लिए, और एक को डेटाबेस कनेक्शन प्रबंधित करने के लिए। एक असली ऐप में आपको इस से ज़्यादा ज़रूरी चाहिए, ज़ाहिर है। यह उदाहरण TableView ट्यूटोरियल के समान मूल उदाहरण का अनुसरण करता है

मान लीजिए आपके डेटाबेस में तीन कॉलम, first_name , last_name , email_address साथ एक person तालिका है।

फिर आप एक Person वर्ग लिखेंगे:

 import javafx.beans.property.StringProperty ; import javafx.beans.property.SimpleStringProperty ; public class Person { private final StringProperty firstName = new SimpleStringProperty(this, "firstName"); public StringProperty firstNameProperty() { return firstName ; } public final String getFirstName() { return firstNameProperty().get(); } public final void setFirstName(String firstName) { firstNameProperty().set(firstName); } private final StringProperty lastName = new SimpleStringProperty(this, "lastName"); public StringProperty lastNameProperty() { return lastName ; } public final String getLastName() { return lastNameProperty().get(); } public final void setLastName(String lastName) { lastNameProperty().set(lastName); } private final StringProperty email = new SimpleStringProperty(this, "email"); public StringProperty emailProperty() { return email ; } public final String getEmail() { return emailProperty().get(); } public final void setEmail(String email) { emailProperty().set(email); } public Person() {} public Person(String firstName, String lastName, String email) { setFirstName(firstName); setLastName(lastName); setEmail(email); } } 

डेटाबेस से डेटा तक पहुंचने के लिए एक क्लास:

 import java.sql.Connection ; import java.sql.DriverManager ; import java.sql.SQLException ; import java.sql.Statement ; import java.sql.ResultSet ; import java.util.List ; import java.util.ArrayList ; public class PersonDataAccessor { // in real life, use a connection pool.... private Connection connection ; public PersonDataAccessor(String driverClassName, String dbURL, String user, String password) throws SQLException, ClassNotFoundException { Class.forName(driverClassName); connection = DriverManager.getConnection(dbURL, user, password); } public void shutdown() throws SQLException { if (connection != null) { connection.close(); } } public List<Person> getPersonList() throws SQLException { try ( Statement stmnt = connection.createStatement(); ResultSet rs = stmnt.executeQuery("select * from person"); ){ List<Person> personList = new ArrayList<>(); while (rs.next()) { String firstName = rs.getString("first_name"); String lastName = rs.getString("last_name"); String email = rs.getString("email_address"); Person person = new Person(firstName, lastName, email); personList.add(person); } return personList ; } } // other methods, eg. addPerson(...) etc } 

और फिर एक UI वर्ग:

 import javafx.application.Application ; import javafx.scene.control.TableView ; import javafx.scene.control.TableColumn ; import javafx.scene.control.cell.PropertyValueFactory ; import javafx.scene.layout.BorderPane ; import javafx.scene.Scene ; import javafx.stage.Stage ; public class PersonTableApp extends Application { private PersonDataAccessor dataAccessor ; @Override public void start(Stage primaryStage) throws Exception { dataAccessor = new PersonDataAccessor(...); // provide driverName, dbURL, user, password... TableView<Person> personTable = new TableView<>(); TableColumn<Person, String> firstNameCol = new TableColumn<>("First Name"); firstNameCol.setCellValueFactory(new PropertyValueFactory<>("firstName")); TableColumn<Person, String> lastNameCol = new TableColumn<>("Last Name"); lastNameCol.setCellValueFactory(new PropertyValueFactory<>("lastName")); TableColumn<Person, String> emailCol = new TableColumn<>("Email"); emailCol.setCellValueFactory(new PropertyValueFactory<>("email")); personTable.getColumns().addAll(firstNameCol, lastNameCol, emailCol); personTable.getItems().addAll(dataAccessor.getPersonList()); BorderPane root = new BorderPane(); root.setCenter(personTable); Scene scene = new Scene(root, 600, 400); primaryStage.setScene(scene); primaryStage.show(); } @Override public void stop() throws Exception { if (dataAccessor != null) { dataAccessor.shutdown(); } } public static void main(String[] args) { launch(args); } } 

(मैंने सिर्फ टाइप किया है कि बिना परीक्षण के, इसलिए हो सकता है कि टाइपो, अनुपलब्ध आयात आदि हो, लेकिन आपको यह विचार देने के लिए पर्याप्त होना चाहिए।)

जेम्स के उत्तर के अलावा :

मैं एक दूरस्थ (MySQL) डेटाबेस से कनेक्ट करना चाहता था, इसलिए मैंने कन्स्ट्रक्टर को बदल दिया और केवल यूआरएल से जुड़े:

 public UserAccessor(String dbURL, String user, String password) throws SQLException, ClassNotFoundException { connection = DriverManager.getConnection(dbURL, user, password); } 

इनट के माध्यम से:

 UserAccessor userAccessor = new UserAccessor( "jdbc:mysql://xxx.xxx.xxx.xxx:YOUR_PORT", "YOUR_DB_USER", "YOUR_PASSWORD") 

कृपया ध्यान दें: आपको कनेक्टर बीबी भी शामिल करना होगा। मैंने mysql-connector-java-5.1.40-bin.jar जो mysql-connector-java-5.1.40-bin.jar के साथ आया था और /Users/martin/Library/Preferences/IntelliJIdea2017.1/jdbc-drivers/MySQL Connector/J/5.1.40/mysql-connector-java-5.1.40-bin.jar अंतर्गत स्थित था /Users/martin/Library/Preferences/IntelliJIdea2017.1/jdbc-drivers/MySQL Connector/J/5.1.40/mysql-connector-java-5.1.40-bin.jar

यश जेम्स_D के हैं