草庐IT

【PostgreSQL】存储过程

全部标签

google-app-engine - GAE Go - 如何将私有(private)变量放入数据存储区?

我正在编写GoogleAppEngineGolang应用程序。我想要一个带有私有(private)变量的struct,这些变量只能通过适当的函数设置,例如:typeFoostruct{barstring}func(f*Foo)SetBar(bstring){f.bar="BAR:"+b}我希望能够将此数据保存在数据存储区中。但是,数据存储区似乎没有保存私有(private)变量。如何在数据存储中存储私有(private)变量? 最佳答案 如果你的类型实现了PropertyLoadSaverinterface就可以:func(f*Fo

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

architecture - 在 Go 中存储状态

我正在用Go编写一个简单的程序作为学习这门语言的练习。该程序是一个游戏播放器:它exec.Command是一个基于文本的游戏,然后通过StdinPipe/StdoutPipe与其通信。在四处闲逛并阅读了大量在线文档之后,我设法使框架正常工作——相当于HelloWorld,我在其中建立了双向通信并可以处理程序终止等错误。现在我正在尝试编写实际玩游戏的AI代码。因为我的目的是学习这门语言,所以我尝试在风格上非常小心——我不只是想在Go中编写C(或其他语言)。程序中明显的分工(一旦完成所有设置)分为两部分。首先,程序查看当前状态并决定应该向游戏发出什么命令。其次,程序查看返回的数据并相应地更

google-app-engine - Google appengine,运行繁重的数据存储写入cron作业的最便宜的方式?

我有一个用Go编写的Googleappengine应用程序,它有一个每天凌晨3点运行一次的cron进程。这个过程会查看当天我的数据发生的所有变化,并存储一些关于发生的事情的元数据。我的用户可以运行有关此元数据的报告,以查看几个月内发生的趋势。该进程每晚执行大约10-20百万次数据存储写入。一切正常,但自从我开始运行它后,我注意到我每月从Google支付的账单显着增加(从每月50美元左右增加到每月400美元左右)。我刚刚设置了一个运行它的非常基本的任务队列,我根本没有更改默认设置。有没有更好的方法可以让我在晚上运行这个过程来省钱?我从来没有弄乱过后端(现在已经折旧)或模块api,而且我知

json - Go语言和PostgreSQL 9.4

是否有支持PostgreSQL9.4版本的Go语言的PostgreSQL库。PostgreSQL9.4支持JSON数据类型,想知道它是否可以与Go语言一起使用?谢谢。 最佳答案 是的,gopqlibrary应该支持PostgreSQLv9.4并且它基本支持JSON类型作为字符串(这似乎是addedinv9.2)。//CREATETABLEfoo(idSERIALPRIMARYKEY,stuffjson);//INSERTINTOfoo(stuff)VALUES('{"x":123}');typeFoostruct{Idint,Stu

google-app-engine - App Engine 数据存储区 : How to set multiple values on a property using golang?

我正在尝试使用Golang为Google数据存储中的单个属性保存多个值。我有一片int64,我希望能够存储和检索它。从文档中我可以看到通过实现PropertyLoadSaver{}接口(interface)支持这一点。但我似乎无法想出正确的实现方式。本质上,这就是我想要完成的:typePoststruct{TitlestringUpVotes[]int64`json:"-"xml:"-"datastore:",multiple"`DownVotes[]int64`json:"-"xml:"-"datastore:",multiple"`}c:=appengine.NewContext(

postgresql - golang中改进的FNV-1 hash算法

原生库有FNV-1哈希算法https://golang.org/pkg/hash/fnv/返回uint64值(范围:0到18446744073709551615)。我需要将此值存储在PostgreSQLbigserial中,但它的范围是1到9223372036854775807。可以将哈希大小更改为例如。56?http://www.isthe.com/chongo/tech/comp/fnv/index.html#xor-fold有人可以帮助更改native算法以生成56位哈希吗?https://golang.org/src/hash/fnv/fnv.go更新我自己是用这个文档做的吗h

windows - 在 Windows 服务中存储配置数据的推荐方法是什么?

因此,我使用thisAPI在Go中编写了一个Windows服务.一切正常,但我想知道在服务中存储配置数据的最佳方式是什么。通常,我使用SHGetKnownFolderPath进入AppData目录并在其中创建我的应用程序目录。然而,在服务中,这为我提供了C:/Windows/system32/config/userprofile中的路径,这在技术上很好,因为我可以在那里做我需要的,但我想知道是否有一个首选存储配置的方式。为此使用注册表更好吗?或者Windows上是否还有其他用于此目的的东西?在这种情况下,Windows系统管理员对服务有什么期望?谢谢。 最佳

go - 如何在 json 的接口(interface)中存储不同的结构

http://play.golang.org/p/JJnU5ag234我只能让vA直接工作,如果我想根据我期望的json使用我的vI在其中存储A或B,我得到json:无法将对象解码为main.TA类型的Go值packagemainimport("encoding/json""fmt""strings")typeTinterface{Printer()}typeAstruct{JAstring}func(tA)Printer(){fmt.Print("A")}typeBstruct{JBstring}func(tB)Printer(){fmt.Print("B")}varvA[]Avar

google-app-engine - 每次使用 App Engine 中的数据存储都会超时

我第一次使用谷歌云环境,特别是谷歌应用引擎和数据存储,当我在本地运行时一切正常。我根据文档通过设置环境变量GOOGLE_APPLICATION_CREDENTIALS对数据存储进行身份验证。但是一旦我部署到应用程序引擎,请求总是超时,似乎GetAll方法永远不会返回。以下是我的应用程序的代码:packageappimport("fmt""net/http""time""golang.org/x/net/context""google.golang.org/appengine""google.golang.org/cloud/datastore")typeUserstruct{First