Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 2565|回复: 6

看看这句SQL语句改成sql20000数据库后不能执行的原因

[复制链接]
发表于 2013-2-26 08:48 | 显示全部楼层 |阅读模式
c = cnn.Execute("select 'C' & format(val(mid(max(单据编号),2))+1,'000000') as 新单号 from crk where 单据编号 like '%C%'").Fields(0).Value,这句SQL语句改成sql20000数据库后为什么不能执行啊,错误提示mid不能识别的函数
发表于 2013-2-26 09:09 | 显示全部楼层
不能识别的函数,说明该版本不支持MID函数
还有个可能,
MID 函数应有3个参数,你的语句里MID只有2个参数,是不是少了个参数?
回复

使用道具 举报

 楼主| 发表于 2013-2-26 09:13 | 显示全部楼层
应该不是这原因,用ACEESSE数据库一点问题都没有,但我改成SQL数据库后就不行了,好像说是这两个数据库有区别,但我不知道怎么修改这个语句
回复

使用道具 举报

发表于 2013-2-26 09:32 | 显示全部楼层
ybc76 发表于 2013-2-26 09:13
应该不是这原因,用ACEESSE数据库一点问题都没有,但我改成SQL数据库后就不行了,好像说是这两个数据库有区 ...


SQL 2000 没有 MID 函数
与MID函数 功能相同的是 substring 函数,用法与 MID 函数相同
如果2个参数不好用,就不要省略第3个参数

mid(max(单据编号),2))
改成substring(max(单据编号),2),1)
回复

使用道具 举报

 楼主| 发表于 2013-2-26 09:52 | 显示全部楼层
哎,又变成是val不能识别了,晕
回复

使用道具 举报

发表于 2013-2-26 20:07 | 显示全部楼层
val是vb函数,不可用在sql server
回复

使用道具 举报

发表于 2013-2-26 22:13 | 显示全部楼层
ybc76 发表于 2013-2-26 09:52
哎,又变成是val不能识别了,晕

val 改成CINT
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-4 14:15 , Processed in 0.391413 second(s), 10 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表