草庐IT

对数据库

全部标签

go - 使用 go-mocket 模拟 GORM 数据库不起作用

我正在尝试使用go-mocket来模拟gorm数据库,但它无法正常工作。我没有向我的ClusterExists函数发送任何模拟数据,因此单元测试无法按预期工作。在文档中有两种模拟“简单链用法”和“FakeResponse”的方法。我已经尝试了两种方法,但都不起作用。我的功能:funcClusterExists(cluster*Cluster,db*gorm.DB)bool{c:=Cluster{}exists:=!db.Where("cluster_name=?ANDenv_type=?",cluster.ClusterName,cluster.EnvType).First(&c).R

google-app-engine - 无法在 golang 中对数据存储类型的实体进行排序

在我的应用程序中,我使用go1.11作为后端。它在谷歌数据存储中执行CRUD操作。我可以从特定种类中检索实体,但顺序不可预测。我正在使用以下数据存储模块:"cloud.google.com/go/datastore"我的结构是:typeRuleDSstruct{Idstring`json:"id"datastore:"id"`Namestring`json:"name"datastore:"name"`Salienceint`json:"salience"datastore:"salience"`CreatedAttime.Time`json:"createdAt"datastore:

mysql - 如何在我的 Go 程序中运行测试之前获取数据库模式

我必须为数据库交互运行Go测试。数据库模式位于.sql文件中。我有一个包含main包的文件夹A,我在A中有3个文件夹B、C和D,它们分别包含包B、C和D。B、C、D中有测试文件,但A没有任何测试。我想要一种方法,这样我就可以做一个gotest./...从A开始,我的所有测试都在将架构采购到mysql之后运行。我尝试在A中创建一个main_test.go文件并在其中放置一个TestMain函数。但它不起作用。 最佳答案 你可以在main_test.go上使用init函数packagemainfuncinit(){//loadandex

go - 遍历对数组

我试图通过一些简单的图表更好地理解golang。我正在上课时尝试这个,但我真的弄不明白。问题是我知道解决方案非常简单。我试图通过读取边缘来让它打印出每条单独的路径。我玩过很多代码,这真的是我能得到的最简单的形式。packagemainimport"fmt"typeGraphstruct{Edgesmap[string][]string}//NewGraph:Creategraphwithnnodes.funcNewGraph()*Graph{return&Graph{Edges:make(map[string][]string),}}//AddEdge:Addanedgefromuto

mysql数据库在golang中报错【sql : database is closed】

我尝试在golang中设置mysql数据库。我为mysql设置创建了db.go并将其导入main.go。但是当我运行main.go时,由于db.go而发生错误。我想解决这个错误。没有编译错误。但是在运行gorunmain.go时,出现错误。主.gopackagemain//importfuncmain(){err:=godotenv.Load()iferr!=nil{}db:=db.NewDatabase(os.Getenv("MYSQL_USER"),os.Getenv("MYSQL_PASSWORD"),os.Getenv("MYSQL_HOST"))s3:=s3.NewS3(os

你游戏上“云”了吗?华为云数据库RDS指南

你游戏上“云”了吗?华为云数据库RDS指南最近,又听闻隔壁的游戏发烧友唠叨:某某游戏开服就被炸服啦,宣发做得再好,给玩家再多的游戏补偿也没用,准备工作都没做好,毫无诚意,这样的游戏质量迟早要完……据说,该游戏虽不是什么游戏大厂出品,但好歹也是个热门IP,开服超乎预料的人气导致过大的访问量,游戏厂商的数据库不足以承载开服高峰访问量,故而炸服状况频出,游戏开服大喜日子却惨遭玩家笑话。游戏厂商如何更好地应对类似这样的尴尬状况?游戏上“云”,或许就是最稳妥的应对措施,也是游戏行业的大势所趋。 游戏上线华为云数据库RDS助你轻松应对简单介绍一下华为云数据库RDS(RelationalDatabaseSe

sql - 使用数据库/sql 包创建通用代码?

我最近实现了apackage使用database/sql包。通过将SQL限制为非常简单的选择/更新/插入语句,我假设该包可以与database/sql支持的所有DBMS一起工作。然而,事实证明有些数据库使用?作为占位符值,而其他数据库使用$1、$2等,这意味着准备好的语句适用于某些DBMS,但不适用于其他DBMS。所以我想知道是否有任何技术可以使所有受支持的驱动程序以通用方式工作?或者是否有必要在所有地方都使用特定于DBMS的代码?(我认为这会使database/sql提供的抽象有点毫无意义)。我想使用非准备语句也不是一个选项,因为不同的DBMS有不同的方法来转义参数。有什么建议吗?

database - 无法获取更新查询的数据库响应以在 go 中进一步执行

我想更新远程数据库表中的数据并执行进一步的任务但无法执行。在插入查询中使用相同的代码,我能够在同一个表中插入值,我很快就会得到响应并继续执行进一步的任务。但在更新查询中,它确实更新了表中的值,但无法继续。这是我尝试过的示例代码:packagesrcimport("github.com/go-sql-driver/mysql""database/sql""fmt""log""net")const(DB_NAME="test_db"DB_HOST="remotedbipaddress:port"DB_USER="username"DB_PASS="password")const(buffe

c++ - 分离与合并由静态语言的数据库表制成的对象

考虑在数据库中有一个名为users的表和一个名为wallets的表。除其他事项外,用户拥有0个、1个或多个钱包。这种关系是一对多的,这意味着钱包有一个指向用户的外键。现在的问题是:当为一个人构建结构或类时,我看到两种可能性:1)用户没有钱包痕迹。有一个函数将用户作为参数并获取钱包数组。2)用户有一个成员,它是一个包含钱包的数组,并且在创建对象/结构时获取钱包。我认为第一种方法可能更好,因为它更加模块化-在第二种方法中,用户依赖于钱包,即使用户没有钱包。不过,我不确定哪种方法更好,所以我正在寻找两种方法的比较。 最佳答案 在应用程序级

mysql - 将数据库集成到 Go Web 应用程序中的最佳方式

我刚开始使用Go开发Web应用程序。我正在寻找将MySQL数据库集成到我的Web应用程序中的最佳方法。我正在考虑做这样的事情:typeContextstruct{Database*sql.DB}//SomedatabasemethodslikeClose()andQuery()forContextstructhere在我的web应用程序的主要功能中,我会有这样的东西:db:=sql.Open(...)ctx:=Context{db}然后我会将我的Context结构传递给需要数据库连接的各种处理程序。这是一个好的设计决策还是有更好的方法将SQL数据库集成到我的Web应用程序中?