草庐IT

Golang Sql-MySQL - 日期/日期时间 0001 年

coder 2024-07-09 原文

我正在使用 go-sql-driver/mysql 库从 MySQL 实例中提取数据,但遇到了一个问题,即任何 DATE/DATETIME 都没有正确扫描字段,尤其是月份和日期是正确的,但 YEAR YEAR 和 TIME 始终为 0001,时间始终为 00:00:00。

所有其他字段都被正确拉取。有问题的 2 个字段是 date_added (DATE) 和 date_timestamp (DATETIME)

如果有任何帮助,我将不胜感激

示例:

0001-01-01 00:00:00 +0000 UTC

我添加了 parseTime=true 连接参数也没有成功。

连接字符串:

mysql, err := sql.Open("mysql", "username:password@tcp(10.37.42.1:3306)/mydb?parseTime=true")

查询:

var (
    id              int
    result_id       int
    status          string
    product         string
    serial          string
    station         string
    stage           string
    operator        string
    operator_name   string
    failstep        string
    sequence_rev    int
    date_added      time.Time
    date_timestamp  time.Time
    stage_order     int
    is_retest       int
    extra1          string
    extra2          string
    extra3          string
    extra4          string
    extra5          string
    workorder       string
    segment         string
    retest_reason   string
    wo_qty          int
)

queryString := `
    SELECT d.id, d.result_id, status.status AS status, parent.product AS product, parent.serial AS serial, station.station AS station, stage.description AS stage, u.username AS operator, CONCAT(u.first_name, ' ', u.last_name) AS operator_name, d.failstep, 
    d.sequence_rev, d.date_added, d.date_timestamp, d.stage_order, d.is_retest, 
    d.extra1, d.extra2, d.extra3, d.extra4, d.extra5, d.workorder, parent.segment, d.retest_reason, parent.wo_qty 
    FROM test_result_detail d 
    LEFT JOIN test_result parent ON d.result_id=parent.id
    LEFT JOIN test_result_status status ON d.status_id=status.id
    LEFT JOIN seq_test_stage stage ON d.stage_id=stage.id
    LEFT JOIN seq_test_set station ON d.station_id=station.id
    LEFT JOIN auth_user u ON d.operator_id=u.id
    WHERE d.id > ? and d.date_added >= '2016-01-01'
    LIMIT 5`

    rows, err := mysql.Query(queryString, LastDetailResult.LastID)
    if err != nil {
        panic(err.Error()) // proper error handling instead of panic in your app
    }


    // iterate through the rows
    for rows.Next() {
        fmt.Println(rows.Columns())
        err := rows.Scan(&id, &result_id, &status, &product, &serial, &station, &stage, &operator, &operator_name, &failstep, &sequence_rev, &date_added, &date_timestamp, &stage_order, &is_retest, &extra1, &extra2, &extra3, &extra4, &extra5, &workorder, &segment, &retest_reason, &wo_qty)
        if err != nil {
            //fmt.Println(err)
        }

        // find parent record in Mongo
        var Parent ResultDetail
        var emptyParent ResultDetail
        Session.DB("opt").C("serials").Find(bson.M{"serial": serial}).One(&Parent)

        // if parent cannot be found omit the insert
        if Parent == emptyParent {
            fmt.Println("NO PARENT RECORD")
            continue
        }

        // check mongo to see if this is a duplicate record, if so omit
        var Duplicates []ResultDetail
        Session.DB("opt").C("serial_history").Find(bson.M{"parent": Parent.ID}).All(&Duplicates)

        // TODO check for first_pass vs retry
        if Duplicates != nil {
            // is this a detail record, if so omit
            // if not a duplicate but is an additional pass then flag FirstPass = false
            //fmt.Println(Duplicates)
            fmt.Println("Found Duplicates")
        }

        // detail record data cleanup

        // insert into detailed test result collection
        // d := Session.DB("opt").C("serial_history")
        // i := bson.NewObjectId()
        //insertError := d.Insert(&ResultDetail{ID: i, Operator: operator, Station: station, Serial: serial, Extra1: extra1, Extra2: extra2, Extra3: extra3, Extra4: extra4, Extra5: extra5, LegacyID: id, FirstPass: true, Workorder: workorder, Status: status, Product: product, Parent: Parent.ID, FailStep: failstep, WoQTY: wo_qty, DateTimestamp: date_timestamp, Segment: segment, Stage: stage, OperatorName: operator_name, Order: stage_order, Date: date_added})


        fmt.Println(date_timestamp)

    }

最佳答案

我弄清楚发生了什么,我的 var 声明 sequence_rev 中的字段出错了:

error: sql: Scan error on column index 10: converting driver.Value type ("") to a int: invalid syntax.

这是因为该字段不是必需的并且可以为空。我将我的 var 声明从 int 更新为 *int,这解决了下游的日期问题。

sequence_rev *int

关于Golang Sql-MySQL - 日期/日期时间 0001 年,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48433976/

有关Golang Sql-MySQL - 日期/日期时间 0001 年的更多相关文章

  1. ruby-on-rails - date_field_tag,如何设置默认日期? [ rails 上的 ruby ] - 2

    我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问

  2. ruby-on-rails - Ruby 检查日期时间是否为 iso8601 并保存 - 2

    我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby​​是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查

  3. ruby - 检查日期是否在过去 7 天内 - 2

    我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/

  4. ruby-on-rails - 将 Ruby 中的日期/时间格式化为 YYYY-MM-DD HH :MM:SS - 2

    这个问题在这里已经有了答案:Railsformattingdate(4个答案)关闭4年前。我想格式化Time.Now函数以显示YYYY-MM-DDHH:MM:SS而不是:“2018-03-0909:47:19+0000”该函数需要放在时间中.现在功能。require‘roo’require‘roo-xls’require‘byebug’file_name=ARGV.first||“Template.xlsx”excel_file=Roo::Spreadsheet.open(“./#{file_name}“,extension::xlsx)xml=Nokogiri::XML::Build

  5. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  6. ruby-on-rails - ruby 日期方程不返回预期的真值 - 2

    为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998

  7. ruby-on-rails - 事件管理员日期过滤器日期格式自定义 - 2

    是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s

  8. 使用canal同步MySQL数据到ES - 2

    文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co

  9. sql - 查询忽略时间戳日期的时间范围 - 2

    我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时

  10. Ruby 日期参数超出范围 - 2

    我正在尝试使用在我的代码中是动态的Time.local来安排时间。在每个月的第一天,我传递的值是Time.local(2009,9,-1,0)。在PHP中,这会将时间设置为上个月的最后一天。在ruby​​中,我只是得到“ArgumentError:参数超出范围”。是我用错了方法还是什么?谢谢。 最佳答案 您应该使用DateTime类而不是Time。(您可能需要先require'date'并安装activesupportgem。)它比Time更通用,并且可以用DateTime.civil(2009,9-1,-1,0)做你想做的事。为天

随机推荐