Hola,
Je.je .. mi estimado amigo, el problema está bastante extraño como lo presentas. Yo copie tu código en un proyecto con con Microsoft SQL Server 2005, NetBeans 6.7.1, Microsoft SQL Server JDBC Driver 2.0, JDK 6.algo, etc.
El problema es que funciona
bien ... si elimino las partes que ya te mencioné anteriormente, es decir le elimino lo de 'static' a 'public void ingresarCliente', y comento la conexión duplicada que tienes, // Connection con = null;
De allí en adelante funciona perfectamente,
Este es el código que probé basado exclusivamente en el tuyo,
Código Java:
Ver originalpublic static void main
(String[] args
) { try {
ClienteDao c = ClienteDao.getClienteDao(Conexion.getConnection());
c.ingresarCliente(new Cliente("Prueba 1"));
c.ingresarCliente(new Cliente("Prueba 2"));
c.ingresarCliente(new Cliente("Prueba 3"));
c.ingresarCliente(new Cliente("Prueba 4"));
ex.printStackTrace();
}
}
----------
import java.sql.Connection;
import java.sql.DriverManager;
public class Conexion {
String url
= "jdbc:sqlserver://localhost:2403;databaseName=Test"; Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
return con;
}
}
----------
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class ClienteDao {
this.con = con;
}
Cliente cliente = (Cliente) object;
String Sql
= "INSERT INTO PRUEBA(NOMBRE) VALUES(?)"; pst.setString(1, cliente.getNombre());
pst.executeUpdate();
}
public void ingresarCliente
(Cliente cliente
) throws Exception { // Connection con = null;
try {
con = Conexion.getConnection();
ClienteDao clienteDaos = getClienteDao(con);
clienteDaos.ingresar(cliente);
e.printStackTrace();
throw e;
} finally {
if (con != null) {
con.close();
}
}
}
private static ClienteDao clienteDao;
public static ClienteDao getClienteDao
(Connection con
) { if (clienteDao == null) {
clienteDao = new ClienteDao(con);
}
return clienteDao;
}
}
----------
public class Cliente {
public Cliente
(String nombre
) { this.nombre = nombre;
}
return nombre;
}
public void setNombre
(String nombre
) { this.nombre = nombre;
}
}
Si tu código es realmente diferente, puedes subirlo a algún lugar y lo revisamos, pero es muy probable que el problema sea de tu configuración de JDBC y MSSQL, ya hice todas las pruebas necesarias y el código así como está anteriormente, basado en el tuyo funciona perfectamente.
Saludos,
ps:
Si deseas puedes subir el código que mencionas para revisarlo, pero supongo que ha de ser el mismo que pusiste aquí anteriormente.