sqlite3 执行了 insert into 语句,不报错,但没有任何数据写入 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
youthfire
V2EX    数据库

sqlite3 执行了 insert into 语句,不报错,但没有任何数据写入

  •  
  •   youthfire 2019-03-03 01:32:57 +08:00 3621 次点击
    这是一个创建于 2434 天前的主题,其中的信息可能已经有所发展或是发生改变。

    初学 sqlite ( python )

    已经成功尝试把一些数据转移到 db 中,这次不知什么原因,执行了却没有任何数据过去。

    查了一些文档,一般都是没有 commit 导致的,可是我已经 commit 了,其中 value 我用 prit 打印看过,内容都有(10 列,4k 行左右)。用数据库查看器看下来的结果就是只有 table f65,以及一排 column name,没有数据内容。

    求教各位,预先谢谢。还不会用 markdown,手工尽可能排版了,各位将就看。

    df = pd.DataFrame(pd.read_excel(r'/Users/' + username + r'/Documents/working/addf6-5.xlsx', header=0))

    df = df.replace('#NUM!', '')

    value = chain(reversed(grouplist2), df.values.tolist())

    for x in value:

    (4 个空格)x[4] = str(x[4])

    (4 个空格)x[7] = str(x[7])

    cOnn= sqlite3.connect('veradb.db')

    c = conn.cursor()

    c.execute("DROP TABLE IF EXISTS f65")

    conn.commit()

    c.close()

    conn.close()

    cOnn= sqlite3.connect('veradb.db')

    c = conn.cursor()

    c.execute("CREATE TABLE IF NOT EXISTS f65 ('offer', 'code', 'desc', 'engine', 'cost', 'supplier', 'remark', 'podate', 'empty', 'border')")

    c.executemany("INSERT INTO f65 VALUES (?,?,?,?,?,?,?,?,?,?)", value)

    conn.commit()

    c.close()

    conn.close()

    12 条回复    2019-03-04 10:46:08 +08:00
    mingl0280
        1
    mingl0280  
       2019-03-03 04:57:16 +08:00
    你参数都没绑定上去怎么写?写什么?空气么?
    shawnxwang
        2
    shawnxwang  
       2019-03-03 05:11:32 +08:00
    一楼老大哥已经给你答疑解惑了
    noqwerty
        3
    noqwerty  
       2019-03-03 06:19:36 +08:00 via Android
    你这个 4 个空格缩进太灵性了
    greatbody
        4
    greatbody  
       2019-03-03 07:41:29 +08:00
    其实你可以写在 github 里面,然后扔一个链接的。
    youthfire
        5
    youthfire  
    OP
       2019-03-03 10:11:59 +08:00
    @mingl0280 抱歉,没有明白哪步还需要参数,能否拨冗指点下?
    我其他几个文件都是用几乎一样的语句写完并存完了所有数据,唯一的区别只是 column 的 name 不同。
    jingxyy
        6
    jingxyy  
       2019-03-03 11:48:14 +08:00   1
    我没环境 猜一个供 lz debug 参考哈
    大概 create table 那句没写对?字段类型都没有这能创建成功吗?
    youthfire
        7
    youthfire  
    OP
       2019-03-03 12:03:15 +08:00 via iPhone   1
    @jingxyy #6 字段他默认创建 text 的如果不写
    Marsss
        8
    Marsss  
       2019-03-04 08:28:35 +08:00 via iPhone   1
    可能是 value 的格式不符合要求吧,executemany 要求为元组类型,当你一眼看不出问题在哪里的时候,排除法可以协助分析,比如你自己构造一组测试数据,参考官方文档例子构造,测试以后就可以知道是数据的问题还是数据库表的问题了。
    youthfire
        9
    youthfire  
    OP
       2019-03-04 09:56:58 +08:00
    @Marsss 谢谢,确实是这个问题。
    value = chain(reversed(grouplist2), df.values.tolist())
    我尝试了下 print(type(value)), 发现是 <class 'itertools.chain'>
    我如果多加一句 value = sorted(value, key=itemgetter(0)),所有数据就写入正常了。
    正好我这次相比其他文件,不需要进行排序,所以也就没有形成符合要求的类型。

    初学,我并不清楚为什么 value 经过 chain 的合并操作是个 class 而不是 list。包括我调试用 for x in value 来打印 x 的时候感觉也完全跟操作打印 list 中嵌套的 list 展示结果又是符合预期的。
    sarlanori
        10
    sarlanori  
       2019-03-04 10:21:19 +08:00
    既然楼主已经找到问题了,那我就说个其他问题吧,数据库为什么要打开关闭两次呢?
    youthfire
        11
    youthfire  
    OP
       2019-03-04 10:38:23 +08:00
    @sarlanori 你好,用 python 处理 csvwriter 时,没有用 with,都是手工 close 的。印象中执行完一组相关的写入操作后,要及时 close,避免后续再次写入相同文件时报错。也是第一次接触数据库,所以就继承过来了,并不清楚是否必要。
    sarlanori
        12
    sarlanori  
       2019-03-04 10:46:08 +08:00   1
    @youthfire 在你的这段代码里,drop table、create table 以及 insert into 这三个操作应该算是一组了,我个人觉得只用连接一次数据库即可。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2716 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 21ms UTC 11:03 PVG 19:03 LAX 04:03 JFK 07:03
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86