Hubz131 2022-02-14 23:13 采纳率: 50%
浏览 36
已结题

Go操作SQLite代码报错

问题遇到的现象和发生背景

想要学习一下使用Go操作SQLite数据库

问题相关代码,请勿粘贴截图

package main

import (
    "gorm.io/driver/sqlite"
    "gorm.io/gorm"
)

type LogStatistics struct {
    gorm.Model
    logStatisticsId         string
    topVisitArticleList     string
    topCoastTimeRequestList string
    createTime              int64
    updateTime              int64
}

func main() {
    db, err := gorm.Open(sqlite.Open("file::memory:?cache=shared"), &gorm.Config{})
    if err != nil {
        panic("failed to connect database")
    }

    // 迁移 schema
    err = db.AutoMigrate(&LogStatistics{})
    if err != nil {
        return
    }

    // Create
    db.Create(&LogStatistics{topVisitArticleList: "00", topCoastTimeRequestList: "xx"})

    // Read
    var logStatistics LogStatistics
    // 根据整型主键查找
    db.First(&logStatistics, 1)
    // 查找 code 字段值为 D42 的记录
    db.First(&logStatistics, "topVisitArticleList = ?", "00")

    //// Update - 将 logStatistics 的 price 更新为 200
    //db.Model(&logStatistics).Update("Price", 200)
    //// Update - 更新多个字段
    //db.Model(&logStatistics).Updates(Product{Price: 200, Code: "F42"}) // 仅更新非零值字段
    //db.Model(&logStatistics).Updates(map[string]interface{}{"Price": 200, "Code": "F42"})
    //
    //// Delete - 删除 logStatistics
    //db.Delete(&logStatistics, 1)
}
运行结果及报错内容
GOROOT=D:\ProgramData\GOPATH\go1.17.7 #gosetup
GOPATH=D:\ProgramData\GOPATH #gosetup
D:\ProgramData\GOPATH\go1.17.7\bin\go.exe build -o C:\Users\HP\AppData\Local\Temp\GoLand\___go_build_admin_data_show.exe admin_data_show #gosetup
# github.com/mattn/go-sqlite3
cc1plus.exe: warning: command line option '-std=gnu99' is valid for C/ObjC but not for C++
_cgo_export.c: In function 'void _cgo_1ad64cd63b8b_Cfunc__Cmalloc(void*)':
_cgo_export.c:233:53: error: invalid conversion from 'void*' to '_cgo_1ad64cd63b8b_Cfunc__Cmalloc(void*)::<unnamed struct>*' [-fpermissive]
  } __attribute__((__packed__, __gcc_struct__)) *a = v;

Compilation finished with exit code 2
我的解答思路和尝试过的方法

根据网上的一些教程:尝试安装https://jmeubank.github.io/tdm-gcc/articles/2021-05/10.3.0-release的GCC程序,没用,依旧是这个报错

Go初学者,无从下手了

我想要达到的结果

正常运行并能够操作数据库

  • 写回答

3条回答 默认 最新

  • _GX_ 2022-02-15 08:07
    关注

    从错误信息来看,是由用C++编译器编译C文件引起的。在C语言里,void *类型可以隐式转换为其他指针类型,当在C++里却必须显示转换才行。
    解决这个问题,你可以指定用C编译器来编译C文件,比如用gcc编译器

    go env -w "CC=gcc.exe"
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月23日
  • 已采纳回答 2月15日
  • 修改了问题 2月14日
  • 修改了问题 2月14日
  • 展开全部

悬赏问题

  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?
  • ¥15 ubuntu系统下挂载磁盘上执行./提示权限不够
  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 关于#r语言#的问题:差异分析前数据准备,报错Error in data[, sampleName1] : subscript out of bounds请问怎么解决呀以下是全部代码:
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误