Ligação com o oracle na aplicação java
Fiz o download da edição 11g da oracle express e instalei-a.Agora eu quero conectá-lo a partir da aplicação java. Aqui está o meu código de Conexão: -
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:example", "example","password123");
Mas quando estou a tentar ligá-lo, Mostra-me a seguir a excepção.
java.sql.SQLException: Listener refused the connection with the following error:
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:419)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:536)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:228)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:521)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at javaapplication3.JavaApplication3.main(JavaApplication3.java:40)
Mas quando estou a tentar ligar-me à base de dados "xe", Está ligado.
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe", "example","password123");
Não sei porque é que isto está a acontecer?. Por favor, dê-me alguma referência ou pista.
3
Author: louiscoquio, 2012-11-01
4 answers
Acho que estás a confundir o tipo de base de dados. Em
Oracle
, XE
significa Express Edition
da base de dados oracle. ORCL
significa Oracle Corp
.
Em mysql
DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "example","password123");
`test` is a database schema.
Em Oracle XE
DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe", "example","password123");
DriverManager.getConnection("jdbc:oracle:thin:scott/tiger@myhost:1521:orcl","example", "password123");
`example`: database schema name and DB user name are the same.
8
Author: CycDemo, 2017-01-27 11:14:29
Os URLs de ligação para a Oracle estão no formato:
Jdbc:oracle:thin:@HOST:PORT:SID
O SID é um identificador do site. Em uma instalação oracle completa você pode ter vários SIDs, mas para Oracle Express isso sempre será XE
.
Aquilo a que se refere como um "banco de dados" equivale a um "utilizador" no oráculo ("exemplo" no seu código acima). Tabelas, etc... são criados sob esse usuário.
4
Author: Nick Wilson, 2012-11-01 11:30:25
Verifique quais as instâncias que são conhecidas por ouvir executando: serviços lsnrctl
Vê os teus nomes.oraVerifique os seus parâmetros SID para o tipo de erro e o valor dos parâmetros inválidos
0
Author: Alpesh Gediya, 2012-11-01 11:28:52
No padrão URL XE e orcl são os id do serviço para o oráculo. Para a edição expressa Oracle "xe" é utilizada e para a edição empreendida Oracle "orcl" é utilizado..
0
Author: vijaymmali, 2013-12-29 10:38:59