草庐IT

connect2db

全部标签

go - 调用 db.Ping() 时的无限循环

我正在尝试创建到数据库的基本连接。当我尝试使用db.Ping()测试连接时出现问题;一切正常,直到我到达这条线。Ping将程序发送到无限循环(函数调用永远不会返回),我不确定如何解决这个问题。packagemainimport("database/sql""fmt""html/template""net/http"_"github.com/lib/pq"}typePagestruct{NamestringDBStatusbool}const(host="localhost"port=8080user="username"password="password"dbname="GoTest

mysql - 无法使用 *DB.Rows() 获取所有行

我是gorm的新手,所以如果我有什么误解,请指出。我正在使用MySQL编写小型应用程序,我决定使用gorm作为ORM。源代码和输出如下。packagemainimport("fmt""log""github.com/jinzhu/gorm"_"github.com/jinzhu/gorm/dialects/mysql")typeGroupstruct{gorm.ModelNamestring`gorm:"notnull;unique"`}funcopenDB()*gorm.DB{user:="ipmonitor"password:="testpassword"database:="ip

postgresql - 连接 : connection timed out

我已经使用gosql包成功连接到Postgres数据库:...db,err:=sql.Open("postgres",connStr)然后我使用返回的数据库执行(长时间运行的)查询:rows,err:=db.Query(...)我得到了错误:dialtcpxx.xxx.xxx.xx:5432:connect:connectiontimedout我有几个问题:为什么连接超时?我能做些什么来防止它超时吗? 最佳答案 sql.Open()mayjustvalidateitsargumentswithoutcreatingaconnecti

mysql - 无法连接到 DB : database is closed

我有以下项目结构:-main.go-db--dbinit.go在dbinit.go中,我有以下代码:packagedbimport("database/sql"_"github.com/go-sql-driver/mysql")varDb*sql.DBvarerrerrorfuncinit(){Db,err=sql.Open("mysql","myDBCreds")deferDb.Close()}在main.go中我有:packagemainimport(db"./db")funcmain(){deferdb.Db.Close()sqlStatement:=`INSERTINTOtab

python - 是否可以将 Python GAE db.GeoPt 移植到 Go 类型?

我正在努力将最初用Python编写的现有GAE应用程序移植到Go。到目前为止,它非常棒而且相当简单(尽管它并非没有怪癖)。由于此端口将部署到不同版本的同一个GAE应用程序,因此这两个版本将共享同一个数据存储。问题在于原始Python应用程序广泛使用了db.GeoPt类型。我在我的一种类型上实现了自己的自定义PropertyLoadSaver,这样我就可以通过反射了解如何在Go中表示db.GeoPt。但显然db.GeoPt的内存布局与Go中的任何内容都不兼容。有人知道我会怎么做吗?以前有人这样做过吗?这里有一些代码可以让你们更好地了解我在做什么:func(sS*SomeStruct)Lo

mysql - Go:如何使用 sql/db 包从 mysql 检索多个结果

我正在尝试使用Go中的sql/db包从表中获取数据。我的数据库表包含一个用户名“shaw”。有几行用户名shaw在附加的帖子列中有不同的帖子。我有以下代码:开始:funcReadData()string{db,err:=sql.Open("mysql","user1@/my_db")iferr!=nil{fmt.Println(err)}deferdb.Close()vartweetstringrows,err:=db.Query("selecttweetfrompostswhereusername=?","shaw")iferr!=nil{fmt.Println(err)}defer

postgresql - 通过 pq 连接到 PostgreSQL 数据库返回 "bad connection"错误

我正在使用两台不同的计算机在Go和PostgreSQL中制作一个网络应用程序。两台计算机上的设置相同(Ubuntu与最新版本的Go和PostgreSQL)。问题是我无法让我的应用程序连接到笔记本电脑上的数据库。我使用这段代码:func(db*Database)Dial(userstring,passwordstring,dbnamestring){varerrerrordb.Conn,err=sql.Open("postgres","user="+user+"password="+password+"dbname="+dbname+"sslmode=require")iferr!=ni

mongodb - 创建 ObjectId 与让 DB 创建它

我正在使用labixmgo模块作为GoMongo驱动程序。由于Go是并发的(和并行的),在应用程序中生成ObjectId是否安全,还是应该只由数据库来做?如果.Insert()可以返回Id,那将非常简单。但是当我需要它时,我有两种方法可以做到这一点:1)在客户端生成ObjectId并使用...user.ID=bson.NewObjectId()Users.Insert(user)//useuser.IDnormally2)让数据库生成Id并取回...Users.Insert(user)Users.Find(user).One(&user)//useruser.IDnormally第二种

去建立错误 "db.GetUsers undefined (type *gorm.DB has no field or method GetUsers)"

我是golang的新手,正在尝试使用gin+gorm制作API服务器。我尝试构建下面的代码,但出现了type*gorm.DBhasnofieldormethodGetUsers错误。这是一个非常简单的API服务器,我只想从users表中获取所有用户。packagemodelsimport("github.com/jinzhu/gorm"_"github.com/jinzhu/gorm/dialects/postgres")vardb*gorm.DBfuncinit(){varerrerrordb,err=gorm.Open("postgres","host=localhostdbnam

go-zookeeper Connect 在没有有效连接的情况下返回

我有一个关于zookeeper的问题,我正在尝试使用go-zookeeper实现简单的服务发现,我正在使用go-zookeeper:https://github.com/samuel/go-zookeeper我的问题是每当我使用例如连接到zookeeper时:zoo_keeper,_,err:=zk.Connect(s,time.Second)函数立即返回,没有报错,但还没有真正有效的连接。现在,例如,如果我想创建znode,我需要检查什么以确保在这样做之前我有一个有效的连接? 最佳答案 在尝试了几件事之后,感谢Imesha的建议,