【求助】mattn oci8插入Oracle表多个字段报错:ORA-01722: invalid number,再请问oci8库有db.Prepare()函数能准备语句吗?

jimyokl · · 1231 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

在网上没搜到插入多字段的示例,就照库的例子用:1和:2做占位符,查询正常,插入常量ok(如下),用变量插入就报错了,请知道的高手帮忙回答一下,谢谢了。(oci8有像mysql库的prepare函数没) _, err = db.Exec("insert into AUTH_SUCESS_201706_FZ values('a','b','c','d',1,2,3,'e',4,5,6,'f',7,8,'g','h','i')") SQL> select count(*) from AUTH_SUCESS_201706_FZ; COUNT(*) ---------- 1 报错信息: 2017-06-17 04:57:11 <LL_ERROR> ORA-01722: invalid number 使用oerr ora 1722 看解释没看懂说的哪个number无效,是占位符吗? [root@bogon ~]# oerr ora 1722 01722, 00000, "invalid number" // *Cause: The specified number was invalid. // *Action: Specify a valid number. 插入用的代码(下面2种插入方式都报错17222): _, err = db.Exec("insert into AUTH_SUCESS_201706_FZ values(:1,:2,:3,:4,:5,:6,:7,:8,:9,:10,:11,:12,:13,:14,:15,:16,:17)", lineList[0],lineList[1],lineList[2],lineList[3],lineList[4],lineList[5],lineList[6],lineList[7],lineList[8],lineList[9],lineList[10],lineList[11],lineList[12],lineList[13],lineList[14],lineList[15],lineList[16]) _, err = db.Exec("insert into AUTH_SUCESS_201706_FZ values(:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1,:1)", lineList[0],lineList[1],lineList[2],lineList[3],lineList[4],lineList[5],lineList[6],lineList[7],lineList[8],lineList[9],lineList[10],lineList[11],lineList[12],lineList[13],lineList[14],lineList[15],lineList[16]) 使用fmt.Println打印lineList[]内容如下,插入的表是按照字段个数和类型建的: 22675029@879150 A4-5D-36-18-59-45 20170106112643 20170106122730 3647 8192 1 192.168.1.1 100 200 1 202.101.99.163 1905 FZ-JA-1020000000002028f20b826979 591 atm 3/1/1:2454.1900 0/0/0/0/0/0 liantong SQL> desc AUTH_SUCESS_201706_FZ; 表结构: Name Null? Type ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- LOGIN VARCHAR2(128) ANI VARCHAR2(26) START_TIME VARCHAR2(20) END_TIME VARCHAR2(20) DURATION NUMBER(8) KB_IN NUMBER(8) KB_OUT NUMBER(8) IPADDR VARCHAR2(16) PACKETS_IN NUMBER(8) PACKETS_OUT NUMBER(8) TERM_CAUSE NUMBER(4) TERMSERV_ID VARCHAR2(16) TERMSERV_PORT NUMBER(8) TRANS_ID NUMBER(8) AREA_ID VARCHAR2(4) NAS_PORT_ID VARCHAR2(256) V_OPERATOR VARCHAR2(256)

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1231 次点击  
加入收藏 微博
3 回复  |  直到 2017-06-19 04:47:41
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传