Commit inicial

This commit is contained in:
Isidoro Nevares 2026-03-11 17:51:51 +01:00
commit 182d91d2f5
15 changed files with 709 additions and 0 deletions

41
.classpath Normal file
View File

@ -0,0 +1,41 @@
<?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry kind="src" output="target/classes" path="src/main/java">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry excluding="**" kind="src" output="target/classes" path="src/main/resources">
<attributes>
<attribute name="maven.pomderived" value="true"/>
<attribute name="optional" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" output="target/test-classes" path="src/test/java">
<attributes>
<attribute name="test" value="true"/>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry excluding="**" kind="src" output="target/test-classes" path="src/test/resources">
<attributes>
<attribute name="test" value="true"/>
<attribute name="maven.pomderived" value="true"/>
<attribute name="optional" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/jdk-23">
<attributes>
<attribute name="module" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
<attributes>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="output" path="target/classes"/>
</classpath>

3
.gitignore vendored Normal file
View File

@ -0,0 +1,3 @@
/bin/
*.class
/target/

34
.project Normal file
View File

@ -0,0 +1,34 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>aaee_ra3_proy3</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>org.eclipse.jdt.core.javabuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.m2e.core.maven2Builder</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.jdt.core.javanature</nature>
<nature>org.eclipse.m2e.core.maven2Nature</nature>
</natures>
<filteredResources>
<filter>
<id>1772465433562</id>
<name></name>
<type>30</type>
<matcher>
<id>org.eclipse.core.resources.regexFilterMatcher</id>
<arguments>node_modules|\.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__</arguments>
</matcher>
</filter>
</filteredResources>
</projectDescription>

View File

@ -0,0 +1,2 @@
eclipse.preferences.version=1
org.eclipse.jdt.apt.aptEnabled=false

View File

@ -0,0 +1,14 @@
eclipse.preferences.version=1
org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate
org.eclipse.jdt.core.compiler.codegen.targetPlatform=23
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
org.eclipse.jdt.core.compiler.compliance=23
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
org.eclipse.jdt.core.compiler.debug.localVariable=generate
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled
org.eclipse.jdt.core.compiler.problem.forbiddenReference=warning
org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=warning
org.eclipse.jdt.core.compiler.processAnnotations=disabled
org.eclipse.jdt.core.compiler.release=disabled
org.eclipse.jdt.core.compiler.source=23

View File

@ -0,0 +1,4 @@
activeProfiles=
eclipse.preferences.version=1
resolveWorkspaceProjects=true
version=1

112
README.md Normal file
View File

@ -0,0 +1,112 @@
# Maven Resumen rápido
## ¿Qué es Maven?
**Apache Maven** es una herramienta de gestión y automatización de proyectos Java.
Permite compilar, probar, empaquetar y gestionar dependencias de forma automática.
Todo se configura mediante un archivo central llamado `pom.xml`.
---
## Conceptos básicos
### POM (Project Object Model)
Es el archivo `pom.xml`, donde se define:
* Información del proyecto (`groupId`, `artifactId`, `version`)
* Dependencias
* Plugins
* Configuración de compilación
Ejemplo básico:
```xml
<groupId>org.ejemplo</groupId>
<artifactId>mi-proyecto</artifactId>
<version>1.0.0</version>
```
---
## Ciclo de vida de Maven (Build Lifecycle)
El ciclo de vida principal está formado por fases que se ejecutan en orden:
| Fase | Descripción |
| -------- | ------------------------------------------- |
| validate | Comprueba que el proyecto es correcto |
| compile | Compila el código fuente |
| test | Ejecuta los tests |
| package | Empaqueta la aplicación (JAR/WAR) |
| verify | Verifica que el paquete es válido |
| install | Instala el paquete en el repositorio local |
| deploy | Publica el paquete en un repositorio remoto |
Ejemplo de ejecución:
```bash
mvn clean install
```
---
## Repositorios
Maven descarga las dependencias desde repositorios.
Tipos:
* **Local** → en el ordenador (`~/.m2`)
* **Central** → repositorio público de Maven
* **Remoto** → repositorios privados (Nexus, Artifactory)
---
## Dependencias
Las librerías necesarias para el proyecto se declaran en el `pom.xml`.
Ejemplo:
```xml
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.33</version>
</dependency>
```
Maven descargará automáticamente la librería.
---
## Comandos Maven más usados
| Comando | Función |
| ------------- | -------------------------------------------- |
| `mvn compile` | Compila el proyecto |
| `mvn test` | Ejecuta los tests |
| `mvn package` | Genera el JAR/WAR |
| `mvn install` | Instala el artefacto en el repositorio local |
| `mvn clean` | Elimina la carpeta `target` |
---
## Estructura típica de un proyecto Maven
```
proyecto
├─ pom.xml
└─ src
├─ main
│ ├─ java
│ └─ resources
└─ test
└─ java
```
---
## Idea clave
Maven sigue el principio **"Convention over Configuration"**:
si respetas su estructura estándar de proyecto, **necesitas muy poca configuración**.

21
pom.xml Normal file
View File

@ -0,0 +1,21 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.lapaloma.mapamundi</groupId>
<artifactId>aaee_mapamundi</artifactId>
<version>mapamundi-0.0.1</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
</properties>
<dependencies>
<!-- Source: https://mvnrepository.com/artifact/com.mysql/mysql-connector-j -->
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
<version>9.6.0</version>
<scope>compile</scope>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,164 @@
package org.lapaloma.mapamundi;
import java.util.List;
import java.util.Scanner;
import org.lapaloma.mapamundi.dao.IContinenteDAO;
import org.lapaloma.mapamundi.dao.impl.ContinenteDaoJDBC;
import org.lapaloma.mapamundi.vo.Continente;
public class AppMapaMundi {
private Scanner scanner = new Scanner(System.in);
private IContinenteDAO continenteDAO = new ContinenteDaoJDBC();
public static void main(String[] args) {
AppMapaMundi app = new AppMapaMundi();
app.iniciar();
}
private void iniciar() {
String opcion = "";
do {
mostrarMenu();
opcion = scanner.nextLine();
switch (opcion) {
case "1":
crearContinente();
break;
case "2":
buscarPorCodigo();
break;
case "3":
buscarPorNombre();
break;
case "4":
listarContinentes();
break;
case "5":
actualizarContinente();
break;
case "6":
borrarContinente();
break;
case "S":
case "s":
System.out.println("Saliendo de la aplicación...");
break;
default:
System.out.println("Opción no válida");
}
} while (!opcion.equalsIgnoreCase("s"));
scanner.close();
}
private void mostrarMenu() {
System.out.println("\n===== MAPA MUNDI - MENÚ =====");
System.out.println("1. Crear continente");
System.out.println("2. Buscar continente por código");
System.out.println("3. Buscar continente por nombre");
System.out.println("4. Listar todos los continentes");
System.out.println("5. Actualizar continente");
System.out.println("6. Borrar continente");
System.out.println("S. Salir");
System.out.print("Seleccione una opción: ");
}
private void crearContinente() {
System.out.print("Código del continente: ");
String codigo = scanner.nextLine();
System.out.print("Nombre del continente: ");
String nombre = scanner.nextLine();
Continente continente = new Continente();
continente.setCodigo(codigo);
continente.setNombre(nombre);
continenteDAO.crearContinente(continente);
System.out.println("Continente creado correctamente.");
}
private void buscarPorCodigo() {
System.out.print("Introduce el código: ");
String codigo = scanner.nextLine();
Continente continente = continenteDAO.obtenerContinentePorClave(codigo);
if (continente != null) {
System.out.println("Código: " + continente.getCodigo());
System.out.println("Nombre: " + continente.getNombre());
} else {
System.out.println("No se encontró el continente.");
}
}
private void buscarPorNombre() {
System.out.print("Introduce el nombre: ");
String nombre = scanner.nextLine();
List<Continente> lista = continenteDAO.obtenerContinentePorNombre(nombre);
for (Continente c : lista) {
System.out.println(c.getCodigo() + " - " + c.getNombre());
}
}
private void listarContinentes() {
List<Continente> lista = continenteDAO.obtenerListaContinentes();
for (Continente c : lista) {
System.out.println(c.getCodigo() + " - " + c.getNombre());
}
}
private void actualizarContinente() {
System.out.print("Código del continente a actualizar: ");
String codigo = scanner.nextLine();
System.out.print("Nuevo nombre: ");
String nombre = scanner.nextLine();
Continente continente = new Continente();
continente.setCodigo(codigo);
continente.setNombre(nombre);
continenteDAO.actualizarContinente(continente);
System.out.println("Continente actualizado.");
}
private void borrarContinente() {
System.out.print("Código del continente a borrar: ");
String codigo = scanner.nextLine();
Continente continente = new Continente();
continente.setCodigo(codigo);
continenteDAO.borrarContinente(continente);
System.out.println("Continente eliminado.");
}
}

View File

@ -0,0 +1,14 @@
package org.lapaloma.mapamundi.dao;
import java.util.List;
import org.lapaloma.mapamundi.vo.Continente;
public interface IContinenteDAO {
public Continente obtenerContinentePorClave(String codigo) ;
public Continente actualizarContinente(Continente coche) ;
public Continente crearContinente(Continente coche);
public void borrarContinente(Continente coche);
public List<Continente> obtenerListaContinentes();
public List<Continente> obtenerContinentePorNombre(String nombre);
}

View File

@ -0,0 +1,181 @@
package org.lapaloma.mapamundi.dao.impl;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.lapaloma.mapamundi.dao.IContinenteDAO;
import org.lapaloma.mapamundi.gestores.GestorConexionJDBC;
import org.lapaloma.mapamundi.vo.Continente;
public class ContinenteDaoJDBC implements IContinenteDAO {
@Override
public Continente obtenerContinentePorClave(String codigo) {
Continente continente = null;
String sentenciaSQL = """
SELECT * FROM T_CONTINENTE
WHERE codigo=?
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
sentenciaJDBCPreparada.setString(1, codigo);
System.out.println(sentenciaJDBCPreparada);
ResultSet resultadoSentencia = sentenciaJDBCPreparada.executeQuery();
if (resultadoSentencia.next()) {
continente = getLineaFromResultSet(resultadoSentencia);
}
} catch (Exception e) {
e.printStackTrace();
}
return continente;
}
@Override
public Continente actualizarContinente(Continente continente) {
String sentenciaSQL = """
UPDATE T_CONTINENTE
SET nombre_continente=?
WHERE codigo=?
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
sentenciaJDBCPreparada.setString(1, continente.getNombre());
sentenciaJDBCPreparada.setString(2, continente.getCodigo());
System.out.println(sentenciaJDBCPreparada);
sentenciaJDBCPreparada.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
}
return continente;
}
@Override
public Continente crearContinente(Continente continente) {
String sentenciaSQL = """
INSERT INTO T_CONTINENTE (codigo, nombre_continente)
VALUES (?, ?)
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
sentenciaJDBCPreparada.setString(1, continente.getCodigo());
sentenciaJDBCPreparada.setString(2, continente.getNombre());
System.out.println(sentenciaJDBCPreparada);
sentenciaJDBCPreparada.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
}
return continente;
}
@Override
public void borrarContinente(Continente continente) {
String sentenciaSQL = """
DELETE FROM T_CONTINENTE
WHERE codigo=?
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
sentenciaJDBCPreparada.setString(1, continente.getCodigo());
sentenciaJDBCPreparada.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
public List<Continente> obtenerListaContinentes() {
List<Continente> lista = new ArrayList<>();
String sentenciaSQL = """
SELECT * FROM T_CONTINENTE
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
System.out.println(sentenciaJDBCPreparada);
ResultSet resultadoSentencia = sentenciaJDBCPreparada.executeQuery();
while (resultadoSentencia.next()) {
lista.add(getLineaFromResultSet(resultadoSentencia));
}
} catch (Exception e) {
e.printStackTrace();
}
return lista;
}
@Override
public List<Continente> obtenerContinentePorNombre(String nombre) {
List<Continente> lista = new ArrayList<>();
String sentenciaSQL = """
SELECT * FROM T_CONTINENTE
WHERE nombre_continente LIKE ?
""";
try (Connection conexion = GestorConexionJDBC.getConexionSGDB();
PreparedStatement sentenciaJDBCPreparada = conexion.prepareStatement(sentenciaSQL);) {
sentenciaJDBCPreparada.setString(1, "%" + nombre + "%");
System.out.println(sentenciaJDBCPreparada);
ResultSet resultadoSentencia = sentenciaJDBCPreparada.executeQuery();
while (resultadoSentencia.next()) {
lista.add(getLineaFromResultSet(resultadoSentencia));
}
} catch (Exception e) {
e.printStackTrace();
}
return lista;
}
private Continente getLineaFromResultSet(ResultSet resultadoSentencia) throws SQLException {
Continente continente = new Continente();
continente.setCodigo(resultadoSentencia.getString("codigo"));
continente.setNombre(resultadoSentencia.getString("nombre_continente"));
return continente;
}
}

View File

@ -0,0 +1,29 @@
package org.lapaloma.mapamundi.gestores;
import java.sql.Connection;
import java.sql.DriverManager;
public class GestorConexionJDBC {
// Evita que pueda construirse un objeto de la clase.
private GestorConexionJDBC() {
}
public static Connection getConexionSGDB() throws Exception {
Connection conexionSGDB = null;
// Datos URL
String urlBBDD = GestorFicheroConfiguracion.obtenerValor("jdbc.url");
String usuario = GestorFicheroConfiguracion.obtenerValor("jdbc.usuario");
String contrasenya = GestorFicheroConfiguracion.obtenerValor("jdbc.password");
String claseDriver = GestorFicheroConfiguracion.obtenerValor("jdbc.driver");
Class.forName(claseDriver);
conexionSGDB = DriverManager.getConnection(urlBBDD, usuario, contrasenya);
return conexionSGDB;
}
}

View File

@ -0,0 +1,40 @@
/**
*
*/
package org.lapaloma.mapamundi.gestores;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
/**
* @author Isidoro Nevares Martín - IES Virgen de la Paloma
* @date 20 feb 2026
*
*/
public class GestorFicheroConfiguracion {
private static final Properties PROPIEDADES = new Properties();
static {
try (InputStream is = GestorFicheroConfiguracion.class.getClassLoader()
.getResourceAsStream("config.properties")) {
if (is != null) {
PROPIEDADES.load(is);
} else {
throw new IllegalStateException("No se encontró application.properties en el classpath");
}
} catch (IOException e) {
throw new IllegalStateException("Error al cargar application.properties", e);
}
}
/**
* Obtiene el valor asociado a la clave especificada.
*
* @param clave la clave a buscar
* @return el valor o {@code null} si no existe
*/
public static String obtenerValor(String clave) {
return PROPIEDADES.getProperty(clave);
}
}

View File

@ -0,0 +1,44 @@
package org.lapaloma.mapamundi.vo;
/**
*
* Coche: Clase de persistencia que representa un coche de un concesionario.
*
* @author Isidoro Nevares Martín - IES Virgen de la Paloma
* @date 03 marzo 2026
*
*
*/
public class Continente {
private String codigo;
private String nombre;
public Continente(String codigo, String nombre) {
super();
this.codigo = codigo;
this.nombre = nombre;
}
public Continente() {
super();
}
public String getCodigo() {
return codigo;
}
public void setCodigo(String codigo) {
this.codigo = codigo;
}
public String getNombre() {
return nombre;
}
public void setNombre(String nombre) {
this.nombre = nombre;
}
@Override
public String toString() {
return "Coche [codigo=" + codigo + ", nombre=" + nombre + "]";
}
}

View File

@ -0,0 +1,6 @@
# Parámetros de conexión a la base de datos MapaMundi en SGDB MySQL
jdbc.driver = com.mysql.cj.jdbc.Driver
jdbc.url = jdbc:mysql://23.21.171.246:3306/mapa_mundi
jdbc.usuario = isidoronm
jdbc.password = 1234