Exemplo de string de conexão
Essa é uma string de conexão do provider IBM Client Access ODBC driver para se conectar com AS/400.
Variante
Tente isso se você encontrar uma "runtime error 3000; reserved error (-7778); there is no message for this error" mensagem.
Conexão através de diferentes linguagens
C#
Exemplo de código em C# de conexão com AS/400 usando IBM Client Access ODBC driver:
using System;
using System.Data.Odbc;
class DatabaseConnection {
static void Main() {
// Define a string de conexão AS/400 usando IBM Client Access ODBC driver
string connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;";
using (OdbcConnection connection = new OdbcConnection(connectionString)) {
try {
// Abre a conexão
connection.Open();
Console.WriteLine("Conexão aberta com sucesso!");
//
// INSIRA SEU CÓDIGO AQUI
//
} catch (OdbcException ex) {
// Erros específicos do OdbcException
Console.WriteLine("Erro: " + ex.Message);
} catch (Exception ex) {
// Outros erros
Console.WriteLine("Erro: " + ex.Message);
} finally {
// Fecha a conexão
if (connection != null) {
connection.Close();
Console.WriteLine("Conexão fechada.");
}
}
}
}
}
VB.NET
Exemplo de código em VB.NET de conexão com AS/400 usando IBM Client Access ODBC driver:
Imports System
Imports System.Data.Odbc
Module DatabaseConnection
Sub Main()
Dim connectionString As String
' Define a string de conexão AS/400 usando IBM Client Access ODBC driver
connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;"
Using connection As New OdbcConnection(connectionString)
Try
' Abre a conexão
connection.Open()
Console.WriteLine("Conexão aberta com sucesso!")
'
' INSIRA SEU CÓDIGO AQUI
'
Catch ex As OdbcException
' Erros específicos do OdbcException
Console.WriteLine("Erro: " & ex.Message)
Catch ex As Exception
' Outros erros
Console.WriteLine("Erro: " & ex.Message)
Finally
' Fecha a conexão
If connection IsNot Nothing Then
connection.Close()
Console.WriteLine("Conexão fechada.")
End If
End Try
End Using
End Sub
End Module
Node.js
Exemplo de código em Node.js de conexão com AS/400 usando IBM Client Access ODBC driver:
const odbc = require('odbc');
// Define a string de conexão AS/400 usando IBM Client Access ODBC driver
const connectionString = 'Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;';
try {
// Abre a conexão
odbc.connect(connectionString, (error, connection) => {
if (error) {
console.error('Erro:', error.message);
return;
}
console.log('Conexão aberta com sucesso!');
//
// INSIRA SEU CÓDIGO AQUI
//
// Fecha a conexão
connection.close((error) => {
if (error) {
console.error('Erro ao fechar a conexão:', error.message);
return;
}
console.log('Conexão fechada com sucesso!');
});
});
} catch (error) {
console.error('Erro geral:', error.message);
}
Este código requer que você instale o módulo odbc através do seguinte comando:
npm install odbc
PHP
Exemplo de código em PHP de conexão com AS/400 usando IBM Client Access ODBC driver:
<?php
// Define a string de conexão AS/400 usando IBM Client Access ODBC driver
$connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;";
try {
// Abre a conexão usando PDO ODBC
$pdo = new PDO("odbc:" . $connectionString);
//
// INSIRA SEU CÓDIGO AQUI
//
// Fecha a conexão
$pdo = null;
} catch (PDOException $e) {
// Trata erros de conexão ou exceções
echo "Erro: " . $e->getMessage();
}
?>
Importante: o código acima funciona apenas no PHP para Windows com PDO_ODBC ativado. Para ativar este driver PDO, basta editar o arquivo php.ini e incluir a linha extension=php_pdo_odbc.dll após a linha extension=php_pdo.dll.
Python
Exemplo de código em Python de conexão com AS/400 usando IBM Client Access ODBC driver:
import pyodbc
# Define a string de conexão ODBC para AS/400 usando IBM Client Access ODBC driver
connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;"
try:
# Abre a conexão
connection = pyodbc.connect(connectionString)
print("Conexão aberta com sucesso!")
#
# INSIRA SEU CÓDIGO AQUI
#
except pyodbc.Error as e:
print("Erro: ", e)
finally:
# Fecha a conexão
if connection:
connection.close()
Este código requer que você instale o módulo pyodbc através do seguinte comando:
pip install pyodbc
ASP Clássico
Exemplo de código em ASP Clássico de conexão com AS/400 usando IBM Client Access ODBC driver:
<%
Dim conn, connectionString
' Cria a string de conexão para AS/400 usando IBM Client Access ODBC driver
connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;"
Set conn = Server.CreateObject("ADODB.Connection")
' Abre a conexão
On Error Resume Next
conn.Open connectionString
' Verifica se a conexão foi aberta
If conn.State = 1 Then
Response.Write "Conexão aberta com sucesso!"
'
' INSIRA SEU CÓDIGO AQUI
'
Else
If Err.Number <> 0 Then
Response.Write "Erro: " & Server.HTMLEncode(Err.Description)
Else
Response.Write "Erro: A conexão não pode ser estabelecida."
End If
End If
On Error GoTo 0
' Fecha a conexão
conn.Close
Set conn = Nothing
%>
VBScript
Exemplo de código em VBScript de conexão com AS/400 usando IBM Client Access ODBC driver:
Dim conn, connectionString
' Define a string de conexão AS/400 usando IBM Client Access ODBC driver
connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;"
Set conn = CreateObject("ADODB.Connection")
' Abre a conexão
On Error Resume Next
conn.Open connectionString
' Verifica se a conexão foi aberta
If conn.State = 1 Then
Wscript.Echo "Conexão aberta com sucesso!"
'
' INSIRA SEU CÓDIGO AQUI
'
Else
If Err.Number <> 0 Then
WScript.Echo "Erro: " & Err.Description
Else
WScript.Echo "Erro: A conexão não pode ser estabelecida."
End If
End If
On Error GoTo 0
' Fecha a conexão
conn.Close
Set conn = Nothing
Wscript.Echo "Conexão fechada."
JScript
Exemplo de código em JScript de conexão com AS/400 usando IBM Client Access ODBC driver:
var conn, connectionString;
// Define a string de conexão AS/400 usando IBM Client Access ODBC driver
connectionString = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;";
conn = new ActiveXObject("ADODB.Connection");
// Abre a conexão
try {
// Abre a conexão
conn.Open(connectionString);
if (conn.State === 1) {
WScript.Echo("Conexão aberta com sucesso!");
//
// INSIRA SEU CÓDIGO AQUI
//
} else {
WScript.Echo("Erro: A conexão não pode ser estabelecida.");
}
} catch (e) {
// Exibe a mensagem de erro
WScript.Echo("Erro: " + e.description);
} finally {
// Fecha a conexão
conn.Close();
conn = null;
}
C++
Exemplo de código em C++ de conexão com AS/400 usando IBM Client Access ODBC driver:
#include <iostream>
#include <cstdlib>
#include <string>
#include <sql.h>
#include <sqlext.h>
int main() {
// Inicializa o ambiente ODBC
SQLHENV env = SQL_NULL_HENV; // Handle do ambiente ODBC
SQLHDBC dbc = SQL_NULL_HDBC; // Handle da conexão ODBC
SQLRETURN ret; // Status de retorno ODBC
SQLWCHAR outstr[1024]; // String de saída para resultados ODBC
SQLSMALLINT outstrlen; // Contador de caracteres para resultados ODBC
// Aloca um ambiente de manipulação ODBC
ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env);
if (ret == SQL_ERROR) {
std::cout << "Erro ao alocar o ambiente ODBC." << std::endl;
return EXIT_FAILURE;
}
// Define a versão ODBC para a mais recente disponível
SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (void *) SQL_OV_ODBC3, 0);
// Aloca um handle de conexão
ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc);
if (ret == SQL_ERROR) {
std::cout << "Erro ao alocar o handle de conexão ODBC." << std::endl;
SQLFreeHandle(SQL_HANDLE_ENV, env);
return EXIT_FAILURE;
}
// Define a string de conexão AS/400 usando IBM Client Access ODBC driver
std::wstring connectionString = L"Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;";
// Tenta conectar usando a string de conexão
ret = SQLDriverConnectW(dbc, NULL, (SQLWCHAR*)connectionString.c_str(), SQL_NTS, outstr, sizeof(outstr), &outstrlen, SQL_DRIVER_COMPLETE);
if (SQL_SUCCEEDED(ret)) {
std::cout << "Conexão aberta com sucesso!" << std::endl;
//
// INSIRA SEU CÓDIGO AQUI
//
// Desconecta do banco de dados
SQLDisconnect(dbc);
} else {
std::cout << "Falha ao abrir conexão." << std::endl;
}
// Libera os handles alocados
SQLFreeHandle(SQL_HANDLE_DBC, dbc);
SQLFreeHandle(SQL_HANDLE_ENV, env);
return EXIT_SUCCESS;
}
Perl
Exemplo de código em Perl de conexão com AS/400 usando IBM Client Access ODBC driver:
use strict;
use warnings;
use DBI;
# Define a string de conexão AS/400 usando IBM Client Access ODBC driver
my $connection_string = "Driver={Client Access ODBC Driver (32-bit)};System=my_system_name;Uid=Usuario;Pwd=Senha;MGDSN=0;";
eval {
# Abre a conexão
my $dbh = DBI->connect("DBI:ODBC:$connection_string", undef, undef, { PrintError => 0, RaiseError => 1 });
print "Conexão aberta com sucesso!\n";
#
# INSIRA SEU CÓDIGO AQUI
#
# Fecha a conexão
$dbh->disconnect;
};
if ($@) {
print "Erro: $@\n";
}