Comment effectuer la persistance et le stockage de données dans le développement Java, vous avez besoin d'exemples de code spécifiques
Dans le développement Java, la persistance et le stockage de données sont un élément très important. Cela implique de sauvegarder les données sur un disque ou sur un autre support persistant afin qu'elles puissent continuer à être utilisées lors de la réexécution du programme. Cet article présentera les technologies courantes de persistance et de stockage de données en Java et fournira des exemples de code.
1. File IO
File IO est l'une des méthodes de stockage de données les plus basiques et les plus couramment utilisées. En utilisant les flux d'entrée et de sortie et les classes de traitement de fichiers de Java, vous pouvez écrire des données dans des fichiers et lire des données à partir de fichiers si nécessaire.
Exemple 1 : Utiliser un fichier IO pour le stockage de données
import java.io.File; import java.io.FileWriter; import java.io.FileReader; import java.io.BufferedReader; import java.io.IOException; public class FileIODemo { public static void main(String[] args) { String data = "Hello, World!"; String fileName = "data.txt"; // 写入数据到文件 try { FileWriter writer = new FileWriter(fileName); writer.write(data); writer.close(); System.out.println("数据写入成功!"); } catch (IOException e) { e.printStackTrace(); } // 从文件中读取数据 try { FileReader reader = new FileReader(fileName); BufferedReader bufferedReader = new BufferedReader(reader); String line; while ((line = bufferedReader.readLine()) != null) { System.out.println("读取到数据:" + line); } reader.close(); } catch (IOException e) { e.printStackTrace(); } } }
Exemple 2 : Utiliser un fichier IO pour enregistrer et lire des objets
import java.io.Serializable; import java.io.FileOutputStream; import java.io.FileInputStream; import java.io.ObjectOutputStream; import java.io.ObjectInputStream; import java.io.IOException; public class ObjectIODemo { public static void main(String[] args) { // 定义需要保存的对象 Person person = new Person("Alice", 20); // 将对象保存到文件 try { FileOutputStream fileOutputStream = new FileOutputStream("person.ser"); ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream); objectOutputStream.writeObject(person); objectOutputStream.close(); System.out.println("对象保存成功!"); } catch (IOException e) { e.printStackTrace(); } // 从文件中读取对象 try { FileInputStream fileInputStream = new FileInputStream("person.ser"); ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream); Person restoredPerson = (Person) objectInputStream.readObject(); objectInputStream.close(); System.out.println("读取到对象:" + restoredPerson); } catch (IOException | ClassNotFoundException e) { e.printStackTrace(); } } } class Person implements Serializable { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } @Override public String toString() { return "Person [name=" + name + ", age=" + age + "]"; } }
2. Base de données relationnelle
La base de données relationnelle est une méthode de stockage de données efficace, évolutive et durable. Java fournit une variété d'API pour l'exploitation des bases de données, telles que JDBC (Java Database Connectivity) et JPA (Java Persistence API).
Exemple 3 : Utilisation de JDBC pour le stockage de données
import java.sql.Connection; import java.sql.DriverManager; import java.sql.Statement; import java.sql.ResultSet; import java.sql.SQLException; public class JDBCDemo { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/mydb"; String username = "root"; String password = "123456"; try { Connection connection = DriverManager.getConnection(url, username, password); Statement statement = connection.createStatement(); // 创建表 String createTableSQL = "CREATE TABLE IF NOT EXISTS employees (id INT PRIMARY KEY, name VARCHAR(50))"; statement.executeUpdate(createTableSQL); // 插入数据 String insertDataSQL = "INSERT INTO employees VALUES (1, 'Alice'), (2, 'Bob'), (3, 'Charlie')"; statement.executeUpdate(insertDataSQL); // 查询数据 String selectDataSQL = "SELECT * FROM employees"; ResultSet resultSet = statement.executeQuery(selectDataSQL); while (resultSet.next()) { int id = resultSet.getInt("id"); String name = resultSet.getString("name"); System.out.println("id: " + id + ", name: " + name); } statement.close(); connection.close(); } catch (SQLException e) { e.printStackTrace(); } } }
Exemple 4 : Utilisation de JPA pour le stockage de données
import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; import javax.persistence.EntityTransaction; import javax.persistence.Persistence; public class JPADemo { public static void main(String[] args) { // 创建实体管理工厂 EntityManagerFactory factory = Persistence.createEntityManagerFactory("my-persistence-unit"); EntityManager entityManager = factory.createEntityManager(); // 创建事务 EntityTransaction transaction = entityManager.getTransaction(); transaction.begin(); try { // 创建实体对象 Person person1 = new Person("Alice", 20); Person person2 = new Person("Bob", 25); // 保存实体对象 entityManager.persist(person1); entityManager.persist(person2); // 提交事务 transaction.commit(); System.out.println("对象保存成功!"); } catch (Exception e) { e.printStackTrace(); transaction.rollback(); } finally { entityManager.close(); factory.close(); } } } @Entity class Person { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private int id; private String name; private int age; // 省略构造函数、getter和setter等 }
Les technologies de persistance et de stockage de données ci-dessus sont couramment utilisées dans le développement Java et leurs exemples de code. En fonction des besoins réels, le choix de la technologie et de la méthode appropriées pour le stockage des données peut améliorer efficacement la fiabilité et l'efficacité du programme. J'espère que le contenu de cet article vous sera utile !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!