Без опису
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. package driver
  2. import (
  3. "fmt"
  4. "github.com/jmoiron/sqlx"
  5. _ "github.com/lib/pq"
  6. )
  7. type PostgresDriver struct{}
  8. func (d *PostgresDriver) Name() string {
  9. return "postgresql"
  10. }
  11. func (d *PostgresDriver) BuildDSN(config DBConfig) string {
  12. return fmt.Sprintf("host=%s port=%d user=%s password=%s dbname=%s sslmode=disable",
  13. config.Host,
  14. config.Port,
  15. config.Username,
  16. config.Password,
  17. config.Database)
  18. }
  19. func (d *PostgresDriver) Open(config DBConfig) (*sqlx.DB, error) {
  20. dsn := d.BuildDSN(config)
  21. db, err := sqlx.Open("postgres", dsn)
  22. if err != nil {
  23. return nil, err
  24. }
  25. // 使用公共的连接池配置函数
  26. configureConnectionPool(db, config)
  27. // 测试连接
  28. if err = db.Ping(); err != nil {
  29. return nil, err
  30. }
  31. return db, nil
  32. }
  33. func init() {
  34. Register(&PostgresDriver{})
  35. }