草庐IT

database-file

全部标签

file - 在 Go 中写入文件中的字节范围

我正在使用GO下载一个10MB并发block的大文件,如下所示。packagemainimport("fmt""io/ioutil""net/http""strconv")funcmain(){chunkSize:=1024*1024*10//10MBurl:="http://path/to/large/zip/file/zipfile.zip"filepath:="zipfile.zip"res,_:=http.Head(url)maps:=res.Headerlength,_:=strconv.Atoi(maps["Content-Length"][0])//Gettheconte

database - SQLX "missing destination name"在结构标记中使用表名时

问题是当我对对象使用结构标签时,它们无法正常工作。我以前做过同样的事情但没有遇到任何问题的项目,但我不明白为什么。示例:这不起作用:typeCategorystruct{IDint`json:"id"db:"category.id"`Namestring`json:"name"db:"category.name"`Descriptionstring`json:"description"db:"category.description"`}收到错误:*[]Category中缺少目的地名称ID这很好用:typeCategorystruct{IDint`json:"id"db:"id"`Na

file - Golang 使用 bufio.Scanner 多次扫描同一行

我正在编写一个代码来扫描测试文件并将文本替换为其他内容。想用一个下面堆叠的不同文本替换同一组行。我找到的一个选择是使用ioreader的tee函数,但有没有更好的方法来实现同样的目的。例如,我想要实现的是将下面一段文本中的methodtype子字符串替换为不同的字符串,例如GET、POST,ETC。得到如下输出:文本:router.Methods("methodtype").Path(templatepackagespec.MethodtypePath).Handler(kitHttp.NewServer(endpoints.FuncnameEndpointhttptransport.

database - 在 Firestore 中更新值时没有字段错误

我正在尝试使用golang库更新firestore中的文档。出于某种原因,我收到一个错误:“没有字段\"BirthYear\”错误,我不确定为什么。出生年份绝对是我尝试更新的值之一。我假设我错误地配置了我的结构,但我看不出如何配置。这是我的结构和我的更新代码:sharedstructs.ProfiletypeProfilestruct{UIDstring`json:"UID"firestore:"UID"`ContactEmailstring`json:"ContactEmail,omitempty"firestore:"ContactEmail"`BirthMonthint64`js

azure - golang COSMOS DB,快速入门,缺少环境变量 AZURE_DATABASE

更新:初始化函数中使用的GetEnvVarOrExit已弃用。(但可能仍然有效)2。(这有效)快速的解决方案是以这种方式简单地编辑init()函数......funcinit(){//database=utils.GetEnvVarOrExit("AZURE_DATABASE")//password=utils.GetEnvVarOrExit("AZURE_DATABASE_PASSWORD")database="testDBForStart"password="lTy8axgO6O49JaR2GetYourOwnPasswordFromPortala7yNucQ=="}第三个选项是设

database - 未找到实体时的正确错误处理

我正在编写一个包含数据库包的Go应用程序。现在在数据库包中有几个方法,您可以调用它们来获取基于某些字段的实体。我想知道当没有找到实体时,Go中错误处理的最佳实践是什么。我应该在自己的数据库包中返回错误还是返回nil作为值?我知道当没有找到实体时,谷歌的数据存储会返回错误。现在我正在使用gorm,当没有找到实体时它也会返回错误。我想知道您是否可以简单地返回nil作为值而不是返回错误。我漏掉了一点吗? 最佳答案 如果您使用的是gorm,则有一个专门用于该功能的函数;即,//IsRecordNotFoundErrorreturnstrue

database - 如何解决 go 编程语言中的数据库结构问题?

我正在尝试创建postgresql数据库结构以在Golang中自动化系统。此代码有效;packagemainimport("database/sql""fmt"_"github.com/lib/pq")funccheckError(errerror){iferr!=nil{panic(err)}}const(host="localhost"port=5432user="postgres"password="123"dbname="DatabaseName")funcmain(){psqlInfo:=fmt.Sprintf("host=%sport=%duser=%s"+"passwor

file - 在 Golang 中记录和查找 CSV 文件位置

我需要读取一个CSV文件并将具有特定值的行的位置记录到一个数组中,然后返回并以不特定的顺序检索这些行并且性能良好,因此随机访问。我的程序使用csv.NewReader(file),但我看不到获取或设置它使用的文件偏移量的方法。我试过file.Seek(0,io.SeekCurrent)返回文件位置,但它在调用reader.Read()之间没有变化。我还尝试了fmt.Println("+v+v\n",reader,file)来查看是否有任何东西存储了读者的文件位置,但我没有看到它。如果找到文件位置,我也不知道使用文件位置的最佳方式。这是我需要做的:file,_=os.Open("stuf

go - 实现 tus-file-uploader 时 http.handle 和 gorilla.mux 的区别

我正在尝试根据其网站上提供的示例实现一个tus文件uploader(tus.io)。一切正常,直到我从http.Handle("/files/",http.StripPrefix("/files/",handler))到r.Handle("/files/",http.StripPrefix("/files/",handler))像这样声明r:r:=mux.NewRouter()当尝试调用PATCH-Request上传文件时,使用gorilla路由器使tus-server回复404。问题:http-Handle与上例中给出的r.Handle有哪些不同?也许它不服务PATCH-Reques

带有 journal_mode=WAL 的 go-sqlite3 给出 'database is locked' 错误

在go中,我使用mattn/go-sqlite3模块打开了一个sqlite3数据库。我在使用PRAGMAjournal_mode=WAL打开后立即将数据库日志记录模式设置为WAL。但是,如果我在第一个进程运行时尝试从第二个进程打开数据库,则第二个进程无法打开它,而是收到“数据库已锁定”错误。即使我没有执行任何交易,也会发生这种情况。我使用的连接字符串是:"file:mydbfile.db?cache=shared&mode=rwc"(我打算回答我自己的问题,因为调试了很长时间) 最佳答案 如果你想启用journal_mode=WAL