我是 golang 新手,使用 Jmoiron Sqlx 包查询 Postgres 数据库(选择查询)。我正在做的是创建一个 sql 字符串并调用 Select(dest interface{}, query string,args) 方法。虽然它运行良好,但问题是我正在动态生成我的 sql 字符串,因此每个响应的目标结构应该不同。
例如:- 一个查询可以是
Select a,b,c,d from table A ;
其他都可以
Select x,y,z from Table B;
据我了解,应该为 Select Method 定义两个不同的结构,即
Struct Resp1{
a string
b string
c string
d string
}
还有,
Struct Resp2{
x string
y string
z string
}
然后调用 select 作为 db.Select(&resp1,query,args) 和 db.Select(&resp2,query,args)
我在想我是否有可能定义一个通用的 Struct
say Resp3{
a string
b string
c string
d string
x string
y string
z string
}
并且根据我的选择查询只填充匹配的列(即只有 a、b、c、d 用于第一个,x、y、z 用于第二个)。
我尝试搜索但找不到任何线索。
最佳答案
我无法在这里得到答案,因为我需要这个,所以我自己挖掘并找到了如何以有效的方式解决这个问题。
要解决这个问题,可以将所有字符串值定义为 sql.NullString ,将整数定义为 sql.int64 ,将 float 定义为 sql.float64 等。
假设您的表格有 a、b、c、d、e、f 列,对于某些响应,您只需为其他 d、e 等显示 a、b、d 等等。而不是创建不同的结构并将它们映射到 db.Select(...) 语句中只需按如下方式定义您的结构
a sql.NullString `json:"whatever u wish to have as key,omitempty"`
b sql.NullString `json:"b,omitempty"`
c sql.NullString `json:"c,omitempty"`
d sql.int64 `json:"d,omitempty"`
e sql.float64 `json:"e,omitempty"`
请记住 sql.NullString 将编码为 json 并显示一个附加键 (Valid:boolean) 。您可以按照此处的方法修复 How can I work with sql NULL values and JSON in Golang in a good way?
希望这对某人有帮助。!!
关于go - Jmoiron SQLX Golang通用接口(interface),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38994419/
1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,
在Railcasts上,我注意到一个非常有趣的功能“转到符号”窗口。它像Command-T一样工作,但显示当前文件中可用的类和方法。如何在vim中获取它? 最佳答案 尝试:helptags有各种程序和脚本可以生成标记文件。此外,标记文件格式非常简单,因此很容易将sed(1)或类似的脚本组合在一起,无论您使用何种语言,它们都可以生成标记文件。轻松获取标记文件(除了下载生成器之外)的关键在于格式化样式而不是实际解析语法。 关于ruby-on-rails-Textmate'Gotosymbol
我一直在为使用acts_as_list的模型实现一些不错的交互界面,这些界面可以对我的mRails应用程序中的列表进行排序。我有一个排序函数,在每次拖放之后使用sortable_elementscript.aculo.us函数调用并设置每条记录的位置。这是在拖放完成后处理排序的Controller操作示例:defsortparams[:documents].each_with_indexdo|id,index|Document.update_all(['position=?',index+1],['id=?',id])endend现在我正在尝试对嵌套集模型(acts_as_nested
最近在工作中,看到一些新手测试同学,对接口测试存在很多疑问,甚至包括一些从事软件测试3,5年的同学,在聊到接口时,也是一知半解;今天借着这个机会,对接口测试做个实战教学,顺便总结一下经验,分享给大家。计划拆分成4个模块跟大家做一个分享,(接口测试、接口基础知识、接口自动化、接口进阶)感兴趣的小伙伴记得关注,希望对你的日常工作和求职面试,带来一些帮助。注:文章较长有5000多字,希望小伙伴们认真看完,当然有些内容对小白同学不是太友好,如果你需要详细了解其中的一些概念或者名词,请在文章之后留言,后续我将针对大家的疑问,整理输出一些大家感兴趣的文章。随着开发模式的迭代更新,前后端分离已不是新的概念,
我有一个带有多个模型和View页面的Rails4应用程序。我的应用程序的应用程序布局包含一个搜索栏。但它目前处于非事件状态。搜索栏的目的是让用户在所有模型中搜索输入的关键字,基本上使其成为全局搜索。有没有通用搜索的gem?或者它必须通过sql查询手动完成?我可以看到在其View页面上实现对特定模型的搜索的方法。但我希望它一次搜索所有模型。我该怎么办? 最佳答案 我认为在您的情况下最好的方法是使用ElasticSearch。提供了一个简洁的集成gemhere.该页面上提供了指向文档的链接。
我正在尝试在我的Rails应用程序中使用模型来从外部API检索信息。我想做的是以类似于ActiveRecord模型提供的方式(特别是关联,以及相同风格的可链接查询方法)访问我的数据模型(可能包含来自多个API调用的信息)。我最初的直觉是重新创建我想要的ActiveRecord部分并合并此API。不想“重新发明轮子”并确切地看到添加更多功能需要多少工作让我退后一步并重新评估如何处理这个问题。我找到了在没有表的情况下使用ActiveRecord的方法(请参阅:Railscast#193TablelessModel和博客文章here)并研究了ActiveRecord。因为ActiveMode
我正在尝试使用XCode和InterfaceBuilder构建一个基本的helloworld应用程序。但是,在InterfaceBuilder中,我看不到我的socket可以连接起来。我转到对象检查器Pane的连接选项卡,它显示“NewReferencingOutlet”。我想知道我的代码是否有误。在这里classHelloWorldControllerattr_accessor:hello_label,:hello_button,:hellodefawakeFromNib@hello=trueenddefchangeLabel(sender)if@hello@hello_label.
自97年以来我一直在使用vi/vim进行各种快速编辑和管理任务,但最近才考虑使用它来替换Netbeans作为我选择的ruby编辑器。我发现一件事在Netbeans和Eclipse中非常有用的是Ctrl+Click“转到定义”功能,您可以在其中按住Ctrl键并单击一个类或方法,然后它将带您了解定义。现在,我玩过丰富的ctags和rails.vim,而且很接近,但没有雪茄。这就是我想要的:默认情况下在Netbeans和Eclipse中,您可以在本地rails中按住ctrl并单击本地方法或类项目,但你也可以ctrl+click定义在gems或用Ruby编写的系统库。以Netbeans为例
我正在寻找用于ruby的“虚拟文件系统”类型库。我希望能够拥有一个完全通用的文件系统,我可以轻松地在使用本地文件和使用S3或使用FTP或类似的东西之间切换。(等同于Java的VFS)有没有人为ruby使用过任何类型的通用文件系统(我只需要它来支持本地文件和AmazonS3)如有任何指点,我们将不胜感激。 最佳答案 看看Vfs(虚拟文件系统)——它通过本地文件系统、AWSS3、SFTP提供简单而统一的接口(interface)。概览:http://alexeypetrushin.github.com/vfsS3样本:http:
原文:UsetheIComparableandIComparerinterfacesinVisualCSharp本文介绍了在VisualC#中如何使用IComparer和IComparable接口。概要本文同时讨论了IComparable和IComparer接口,原因有两点。这两个接口经常一起使用。虽然接口类似且名称相似,但它们却有不同的用途。如果你有一个支持IComparer的类型数组(例如字符串或整数),你可以对它进行排序而不需要提供任何对IComparer的显式引用(译注:意思是把一个IComparer的实现类作为参数传递给排序方法)。在这种情况下,数组元素会被转换为IComparer的