|
1
|
|
|
package connector |
|
2
|
|
|
|
|
3
|
|
|
import ( |
|
4
|
|
|
"database/sql" |
|
5
|
|
|
"fmt" |
|
6
|
|
|
"time" |
|
7
|
|
|
|
|
8
|
|
|
"github.com/cdleo/go-commons/logger" |
|
9
|
|
|
"github.com/cdleo/go-commons/sqlcommons" |
|
10
|
|
|
"github.com/godror/godror" |
|
11
|
|
|
"github.com/godror/godror/dsn" |
|
12
|
|
|
) |
|
13
|
|
|
|
|
14
|
|
|
type oracleConn struct { |
|
15
|
|
|
connString string |
|
16
|
|
|
user string |
|
17
|
|
|
password string |
|
18
|
|
|
} |
|
19
|
|
|
|
|
20
|
|
|
const oracleProxyName = "godror-proxy" |
|
21
|
|
|
|
|
22
|
|
|
func NewOracleSqlConnector(host string, port int, user string, password string, database string) sqlcommons.SQLConnector { |
|
23
|
|
|
|
|
24
|
|
|
return &oracleConn{ |
|
25
|
|
|
connString: fmt.Sprintf("(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=%s)(PORT=%d))(CONNECT_DATA=(%s)))", host, port, database), |
|
26
|
|
|
user: user, |
|
27
|
|
|
password: password, |
|
28
|
|
|
} |
|
29
|
|
|
} |
|
30
|
|
|
|
|
31
|
|
|
func NewOracleTNSSqlConnector(tnsName string, user string, password string) sqlcommons.SQLConnector { |
|
32
|
|
|
|
|
33
|
|
|
return &oracleConn{ |
|
34
|
|
|
connString: fmt.Sprintf("connectString=%s", tnsName), |
|
35
|
|
|
user: user, |
|
36
|
|
|
password: password, |
|
37
|
|
|
} |
|
38
|
|
|
} |
|
39
|
|
|
|
|
40
|
|
|
func (s *oracleConn) Open(logger logger.Logger, translator sqlcommons.SQLAdapter) (*sql.DB, error) { |
|
41
|
|
|
|
|
42
|
|
|
registerProxy(oracleProxyName, logger, translator, godror.NewConnector(dsn.ConnectionParams{}).Driver()) |
|
43
|
|
|
|
|
44
|
|
|
var connParams godror.ConnectionParams |
|
45
|
|
|
connParams.ConnectString = s.connString |
|
46
|
|
|
connParams.Username = s.user |
|
47
|
|
|
connParams.Password = godror.NewPassword(s.password) |
|
48
|
|
|
connParams.Timezone = time.Local |
|
49
|
|
|
connParams.StandaloneConnection = true |
|
50
|
|
|
|
|
51
|
|
|
return sql.Open(oracleProxyName, connParams.StringWithPassword()) |
|
52
|
|
|
} |
|
53
|
|
|
|
|
54
|
|
|
func (s *oracleConn) GetNextSequenceQuery(sequenceName string) string { |
|
55
|
|
|
return fmt.Sprintf("SELECT %s.NEXTVAL FROM DUAL", sequenceName) |
|
56
|
|
|
} |
|
57
|
|
|
|