关灯
《文稿,还能这样写》作者雄文《笔杆子碎语》作者王一端《机关文稿写作入门》作者杨新宇《机关文字工作五十讲》作者何新国
最新《公文写作培训课程》直播间《公文写作百法例讲》作者房立洲老秘网站长、《老秘笔记》作者老猫《公文高手的自我修养》作者胡森林
开启左侧

Access转sql教程 方法+经验汇总贴

[复制链接]
乐将秘书 发表于 2009-8-25 16:55:10 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题
文稿修改演播室众筹计划,点击了解详情
 

ACCESS转SQL SERVER的数据库的几点经验

c& o. r6 f" C$ ~( O1 f

1.ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编

9 R$ }; y5 ^8 x+ D% |1 B

号!

6 W& L @* X- N# H3 K# R

2.转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime

3 j: u( u" \4 t9 N4 ^7 n+ A" T

型大。我遇见这种情况,用smalldatetime型时,转化失败,而用datetime型时,转化成功。

" }6 l8 d0 y" G

3.对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:"delete * from user where id=10",而对SQL

9 G5 H. L5 M( J3 U: N2 Y

SERVER数据库进行删除是用:"delete user where id=10".

* i1 w7 |, E* Q/ M2 d# p9 W# ^

4.日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对SQL SERVER数据库处理中,只能用datediff,dateadd等函数

0 }5 G" C O% U2 ^0 k

,而不能用date()、time()等函数。

; r8 `8 l9 R- L+ n# u5 m, s

5.在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQL SERVER数据库处理中,却不能用。 

- \! b. m1 _; R. n! M+ s

 

* ]% d; t# r `0 N3 I

--------------------------------------------------------------------------------------

, }: Q, O; C7 X3 t3 y5 \+ i

Access 转成SQL Server2000 数据库的一个绝对成功的好方法 

, o" b1 k5 d! Y! X4 o' D4 r: k

 

, R( a$ Q/ P+ s( X) A7 J# a

前几天在把网站的数据库从access转换成sql是遇到了不少问题,下面的方法可以使转换成功!

4 k/ ^( D% b' I' J$ u. k

动网数据库Access 转成SQL Server2000 数据库的一个绝对成功的好方法:

3 k* q- |: x+ y

步骤如下:

/ x9 {; A5 ~7 r1 |+ x

1、必须先安装Microsoft Office Access 2003,和SQL Server2000。

7 x2 r. f6 D3 d! T/ S* C" t

2、把旧的动网数据库备份,备份完成后,用Access 2003打开动网旧数据库,在打开时会出现一个警告,不要理会它(安全警告),按打开键

+ K; x7 b4 H u5 X. _& s& Y- h

,打开后按工具栏——数据库实用工具——转换数据库——转换为2002-2003格式,把数据库转换成2003格式。

/ k! \6 b2 S/ B$ {3 ^

3、转换完成后再用Access 2003打开,打开后按工具栏——数据库实用工具——升迁向导——新建数据库——填写SQL数据库登陆名称、密码和

7 |; Y, s. E! Q6 J

要新建的动网数据库(准备转成新的动网数据库),按下一步,按“ 》”键,再按下一步,选取所有选项,再按下一步,选择“不对应用程序

- c; q5 t& Y! U4 Y' d0 s! V0 X

作任何改动”,再按完成。

1 L3 d$ H' I& o2 q

4、打开SQL企业管理器——数据库---选中相应的数据库---右键所有任务-----生成SQL脚本——常规——全部显示——编写全部对象脚本——

/ E* E) L" A6 ^! X

确定(记住存放的位置)。

6 T2 f3 ^! Q! u0 \* v+ w: d" O4 z

5、用记事本打开刚才生成的SQL脚本,在编辑栏——替换——查找内容为“datetime”替换为“smalldatetime”——替换全部;完成后再在编

1 P+ g1 d, }2 F

辑栏——替换——查找内容为“nvarchar”替换为“varchar”——替换全部,完成后保存退出。

+ c) N# r5 I1 g; D1 c) R

6、打开SQL企业管理器——数据库——点击这个数据库一下新建的动网数据库,然后在工具栏——SQL查询分析器——文件——打开——“刚才

: u9 ~0 u, ]' ]" u

生成的SQL脚本”——查询——执行,然后关闭窗口。

8 A/ {& g1 i7 h: S" ~7 c2 b

(有的朋友说,用sql版自带的sql脚本也可以,大家不妨试试看)

$ z! U9 s: ?) j) {2 Y; T

7、再回到SQL企业管理器——数据库——点击这个数据库一下新建的动网数据库,然后打开工具栏——数据库转换服务——导入数据——下一

) @2 d( i7 o( Y' B3 n- h; b2 u8 x

步——数据源“Microsoft Access”文件名“为旧的动网数据库”——下一步——再下一步——从源数据复制表和视图——下一步——全选—

) j; i( Q( l3 q$ J R

—下一步——立即运行——下一步——完成。

: p0 Y3 j" k% C, V

 

7 H; R; ^! e. }

把ACCESS转成SQL数据库

& ^! s' h& L3 x9 _; }/ Y: V

很多朋友想用SQL2000数据库的编程方法,但是却又苦于自己是学ACCESS的,对SQL只是一点点的了解而已,这里我给大家提供以下参考---将ACCESS转化成SQL2000的方法和注意事项
一,首先,我说的是在ACCESS2000,SQL2000之间转换,其他的我也还没有尝试过,希望大家多多试验,肯定是有办法的;
二,转换的方法
1,打开”控制面板“下”管理工具“中的”数据库源“;
2,按”添加“添加一个新的数据源,在选择栏里选”Driver do microsoft Access
(*.mdb)”,完成后将出现一个框,

; q5 T- u' {8 K1 O/ n! g$ x6 E& u

在”数据库源“里面输入你想写的名称,我取名叫“ABC”,说明不需要填,接着,按下面的选择,寻找你的数据库地址和选中(注意,请先备份自己的ACCESS数据库),然后确定。
数据源在这里建好了,剩下转换了。

$ R8 x) P1 \/ A# q |4 g

3,打开SQL2000企业管理器,进入数据库,新建一个空的数据库“ABC”;
4,选择新建立的数据库,按鼠标右键,选择“所有任务”下“导入数据”,按“下一步”继续;
5,在数据库源下拉但中选择”Driver do microsoft Access(*.mdb)“,在”用户/系统DSN“中,选种你刚才添加的”ABC“,按 ”下一步“;
6,“目的”不需要修改,选择服务器(一般下为自己的本机“local“,也可以选择服务器地址或者局域网地址,确定你的权限是否可以操作,),“使用WINDOWS 身份验证“指用自己的系统管理员身份操作,“使用SQL身份操作验证“可以用于网站的操作,推荐用后者;
7,选上“使用SQL身份操作验证“后,填写你的用户名和密码,我自己选

 

精彩评论9

正序浏览
乐将秘书 发表于 2009-8-25 16:55:27 | 显示全部楼层
 
公文写作百法例讲
择的是系统默认号码“sa“,“****“,数据库选择刚新建的“ABC“,按“下一步“;
8,这一步的两个单项选择,“从数据源复制表和视图“与“用一条查询指令指定要传输的数据“,选择前者,按“下一步“继续;
9,这里将出现你自己ACCESS数据库的表,按“全选“后,下一步;
10,“DTS导入/导出向导“,看“立即运行“被选中按“下一步“,
11,按“完成“继续;
12,这个步骤你将看到你的数据被导入SQL2000里面,当出现“已经成功把XXX个表导入到数据库“的字样,而且所有的表前面都有绿色的勾,就表示成功导入所有数据,如果中途出现问题或者表前面有红色的叉的话,说明该表没有成功导入,这时就要回去查看自己的操作是否正确了. ) o) o! J% I( A1 E4 b

- ?/ `# E# a% a

三,数据修改
1,由于SQL2000里面没有“自动编号“,所以你的以“自动编号“设置的字段都会变成非空的字段,这就必须手工修改这些字段,并把他的“标示“选择“是“,种子为“1“,增量为“1“,
2,另外,ACCESS2000转换成SQL2000后,原来属性为“是/否“的字段将被转换成非空的“bit“,这时候你必须修改成自己想要的属性了;
3,另外,大家要注意对时间函数的把握.ACCESS与SQL是有很多不同的.

9 z G! M8 c9 Y! t3 Q

ACCESS改为SQL需要注意哪几个地方

" K; Z {& }6 U* b) `0 G& a o- f" W

数据库导入以后,自动增加字段需要重写,所有的数字类型需要增加长度,最好用decimal。

/ K# I) U* `0 n+ h. d2 u$ P! q% h

所有的默认值都丢失了。主要是数字类型和日期类型。

$ V0 I5 y. B8 A" d+ i1 L7 U

所有now(),time(),date()要改成getdate()。

* {# B9 \. y- [* P' a+ _) `

所有datediff(‘d‘, time1, time2)要改成datediff(day, time1, time2)

& U" N1 I/ H u3 W& T' L6 m4 {

有可能一些true/false类型不能使用,要变为1/0。

5 j. d; R. \0 W) W7 q: G- \

备注类型要通过cast(column as varchar)来使用。

" O* _% v+ V. [ C8 u8 n+ Q

CursorType要改成1,也就是打开数据库时要给出第一个数字参数为1,否则记录可能显示不完整。

P9 P3 I5 c! Y* K6 ^# W, U3 J1 y

isnull(rowname)要改成rowname = null

- |8 @, z O) y9 f- h/ Q

ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号!

6 {* G, t8 \ n' }, y0 o# L

转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。有时用smalldatetime型时,转化失败,而用datetime型时,转化成功。

) D6 g# I! H9 _

对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:“delete * from user where id=10“,而对SQL SERVER数据库进行删除是用:“delete user where id=10“.

/ u2 i' U" H. f+ B1 Y- O1 n

日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对SQL SERVER数据库处理中,只能用datediff,dateadd等函数,而不能用date()、time()等函数。

6 e9 I, p9 z' E; [+ Y' z5 Z

在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQL SERVER数据库处理中,却不能用。
ACCESS转SQL SERVER的数据库的几点经验

0 Z. Q; S7 }' F8 r! P% K: ^

1.ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号!
2.转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。我遇见这种情况,用smalldatetime型时,转化失败,而用datetime型时,转化成功。
3.对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:“delete * from user where id=10“,而对SQL SERVER数据库进行删除是用:“delete user where id=10“.
4.日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对SQL SERVER数据库处理中,只能用datediff,dateadd等函数,而不能用date()、time()等函数。
5.在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQL SERVER数据库处理中,却不能用。

$ l( p8 h3 w0 t" o3 X

小工具 http://secfans.blogbus.com/files/11830996300.rar
access转sql数据库注意事项

# n1 {7 a+ g8 ` r# z

Access与Sql Server之ASP代码比较
后台数据库:
[Microsoft Access]

[Microsoft Sql Server]
更换之后,ASP代码应注意要修改的一些地方:

8 B9 K# G2 O6 U4 f& m0 d0 U6 M

[一]连接问题(举例)
[Microsoft Access]
c
[Microsoft Sql Server]
c

& z( T; v5 O' M# h6 }" v0 b

[二]相似函数(举例)

/ a( h. D# W& H7 k+ A& K

[1]DATEDIFF(datepart, startdate, enddate)
其中“datepart”参数可选项如下:
设置 描述
————————————
[Microsoft Access]
年 yyyy
季度 q
月 m
一年的日数 y
日 d
一周的日数 w
周 ww
小时 h
分钟 n
秒 s

- V9 r# c; P6 q1 ]) {

[Microsoft Sql Server]
year yy, yyyy
quarter qq, q
month mm, m
dayofyear dy, y
day dd, d
week wk, ww
hour hh
minute mi, n
second ss, s
millisecond ms

' t0 W2 t& [. _1 l) H

-------------------------

 
 楼主| 乐将秘书 发表于 2009-8-25 17:10:01 | 显示全部楼层
 
老秘网虚拟稿费

基本上差不多,但注意的是在写的时候,
[Microsoft Access]要加引号,如:datediff('d',enddate,'2004/08/01')
[Microsoft Sql Server]则不需要,如:datediff(d,enddate,'2004/08/01')

! |+ O* d7 a; y! y1 ^

[2][Microsoft Access]中可用如cstr等转数据类型函数,而
[Microsoft Sql Server]中则用convert或cast函数,如:
convert(varchar,[amount])等。

0 c; d4 c; w: o1 q8 ~

[3][Microsoft Sql Server]
取当前时间用getdate等等...

- @6 w. v! l/ e& w% [+ S

[三]语句
[Microsoft Sql Server]
可以用
CASE
WHEN THEN
WHEN THEN
...
ELSE
END
语句,而
[Microsoft Access]
不支持。
[Microsoft Access]也不支持between语句
[Microsoft Sql Server]则可以这样写:
[date] between @date1 and @date2
[四]查询表
[Microsoft Sql Server]
可三个及以上表join查询,而
[Microsoft Access]
好像只能两个表联接查询(待权威确认),
而且[Microsoft Sql Server]可用“*=”和“=*”连接符。[五]除零问题
[Microsoft Access]
在碰到除数为零时,自动丢掉相关记录,而
[Microsoft Sql Server]
则会报错,且查询中止。删除代码:
[Microsoft Access]
可以这样写:delete * from [table]
[Microsoft SQL Server]
只能这样写:delete from [table]
多*会报错
_____________________________________
当前日期:
[Microsoft Access]
用date()
[Microsoft SQL Server]
用getdate()如果数据库可能会更换类型的话,可以
在ASP代码中加上如这样:
if inStr(constr,"Microsoft Access") > 0 then
sqlstr=[Microsoft Access][sql代码]
else
sqlstr=[Microsoft Sql Server][sql代码]
end if
(constr--连接字符串)
这样即使改了数据库,也不用改数据库查询更新代码了。
再加:access中有true、false的字段记录,而sql里只有smallint,对应如果在access里有“字段名=true”的,在sql里要改成“字段名=1”

9 m3 q, H1 y/ ~% V, |

网上大部分的免费asp程序使用的是access数据库。但是access数据库作为一个中小型的单机数据库系统,在承担访问量、数据量大的网站应用时,往往就不堪重负了。一般认为,超过50M的access数据库性能就开始明显下降,超过100M以后,出错、运行慢的问题会更加突出。尽管可以如动网7.0以后那样,从程序的角度尽量优化以图提高性能,但是不能从根本上解决问题。
这时也许使用微软的SQL Server数据库就是最可能的办法,当然也可以使用其它的如Oracle、MySQL等等,但是作为改写来说,由于同为微软的产品,改写成SQL Server应该是最省力的办法。

$ }( J' j6 P9 n

一、改写前提:

# H8 ?: R+ e5 I* ]. \/ R/ Y9 ^, l

  系统已经安装好SQL Server2000并且打上了SP3补丁;安装好Office套件里面的Access;使用一个支持纯文本编辑并且带有行号显示的编辑器,推荐Ultra Edit,当然也可以使用FrontPage2003,不过以前的版本行号显示不太好用。

0 V3 G1 n9 z/ S

个人能力要求:会基本的asp语法、access数据库的操作、SQLServer企业管理器的基本操作。

) J0 D, I* p2 c5 s& C

二、数据库的准备

0 r2 \* h: K3 i6 E% z

  一般来说有两种情况:
  1、程序提供了SQL数据库格式:有一个MDF文件,或者提供了创建SQL数据库的SQL脚本文件(后缀名为.sql)。
  如果有mdf文件,可以用企业管理器直接附加上,如果提供的是sql脚本文件,那么就先用企业管理器自己创建一个sql数据库,然后数据库用企业管理器中的查询分析器运行这个脚本创建数据库表。
这样建立的数据库基本不用再去改写什么了。
  2、更多的是没有提供SQL数据库或脚本文件的,这时,就要自己来做这一切了,这也是我们这个帖子主要解决的问题。一般这样的程序会提供一个access数据库,这样你就用企业管理器导入access数据库,导入后需要改写下面一些东西:
  对照原来的access,改写下面的部分:
(1)sql数据库表是没有自动字段的,因此原来access中的自动字段被转换成了普通字段,需要手工改成标识类型,增量为1。
(2)所有的时间字段,如果定义了默认值,那么原来肯定是now(),需要改成getdate()
(3)原来字段的默认值一般都不会自动引入,需要对照原表的字段手工添加。
(4)由于数据库的不同,access和sql的字段类型很多转换后就变化了,比如原来的《是否》字段会被转换成bit或者int,备注字段被转换成longtext,text字段转换成varchar等等,一般来说不会影响程序运行,如果有问题,我们在下面的程序改写部分再说。
(5)如果你要用一个For SQL的程序,里面用到了存储过程,那么你应该有这个程序本身建立SQL数据库的方法:有其本身的SQL数据库文件,或者sql脚本;如果没有的话,采用导入access数据库的方式是无法建立存储过程的,这样你最好放弃这个For SQL的程序版本,使用同样版本的For Access的程序,导入access数据库,然后用下面的改写方法自己改成SQL版本的程序。

' e: e* |" b7 `# u* @' h* C3 S

三、连接字符串的改写

C7 U5 J% j M( W2 M$ r9 t6 Z

  可参考动网的这段,分别是针对access和SQL的
Dim ConnStr
If IsSqlDataBase = 1 Then

 
 楼主| 乐将秘书 发表于 2009-8-25 17:10:48 | 显示全部楼层
 
专业写文章
'sql数据库连接参数:数据库名、用户密码、用户名、连接名(本地用local,外地用IP)
Dim SqlDatabaseName,SqlPassword,SqlUsername,SqlLocalName
SqlDatabaseName = "dvbbs7"
SqlPassword = ""
SqlUsername = "dvbbs"
SqlLocalName = "(local)"
C & SqlUsername & "; Password = " & SqlPassword & "; Initial Catalog = " & SqlDatabaseName & "; Data Source = " & SqlLocalName & ";"
Else
'免费用户第一次使用请修改本处数据库地址并相应修改data目录中数据库名称,如将dvbbs6.mdb修改为dvbbs6.asp
Db = "data/fengerqingqing.mdb"
C & Server.MapPath(db)
End If
On Error Resume Next
Set conn = Server.CreateObject("ADODB.Connection")
conn.open ConnStr , K% A) S) E+ ]# | r3 y

% P0 [0 p K) l% A/ c1 p7 X- H( G! x

  当然你使用SQL的话,有关access的使用语句可以删除,就是else后面到on error resume next前面,变成这样:

8 C5 N* W+ a/ p8 |) I4 w

Dim ConnStr
'sql数据库连接参数:数据库名、用户密码、用户名、连接名(本地用local,外地用IP)
Dim SqlDatabaseName,SqlPassword,SqlUsername,SqlLocalName
SqlDatabaseName = "dvbbs7"
SqlPassword = ""
SqlUsername = "dvbbs"
SqlLocalName = "(local)"
C & SqlUsername & "; Password = " & SqlPassword & "; Initial Catalog = " & SqlDatabaseName & "; Data Source = " & SqlLocalName & ";"
On Error Resume Next
Set conn = Server.CreateObject("ADODB.Connection")
conn.open ConnStr

% u% L! T1 i; D

也可以简洁一些,写成这样:
Set conn = Server.CreateObject("ADODB.Connection")
conn.open "Provider = Sqloledb; User ID = sa; Password = 1234567; Initial Catalog = dvbbs7; Data Source = (local);"
  里面的数据库名称、数据源、用户、密码根据自己的实际情况改写一下。

* k( m0 M& w3 [3 U) R+ B- [

四、程序的改写

. e5 F* G- }2 m

  这也有两种情况
  1、如果你幸运,拿到的是For SQL的程序,那么如果上面的数据库建立过程没有遇到麻烦,程序基本上就可以运行了,出错的话,只是程序本身的bug,如何修改不是这个帖子讨论的内容,就不赘述了。
  2、大多数情况,程序本身是For Access的,与For SQL的程序差别主要是程序中使用到的SQL查询语句。注意,SQL查询语句是数据库应用不可缺少的部分,不管是For SQL还是For Aceess的程序使用的语法大体差不多,但是有一些微妙的差别,正是这些差别,造成了程序的不通用,也是我们需要修改的主要内容。这样一般要修改的部分如下:
(1)时间函数的问题:SQL数据库的时间函数与access不同,最常见的是取现在时间的函数,access是now(),SQL是getdate()。因此凡是在where子句中使用了now()的地方都要改成getdate();注意,now()函数在asp程序本身也要使用,凡是不在数据库查询或执行语句中使用的now()函数千万不要改。
(2)时间比较函数:datediff('d','时间1',‘时间2’)这是access查询用的格式,SQl中这些引号都要去掉,同时时间格式的前后可能加上了#,这也要去掉。同样这也是指在sql语句中的,在asp语句中的要保持原样。
(3)空值的表示:在access中,判断空值一般用是否=""来表示,但是这在SQL中往往出错,如果遇到出错的问题或者程序运行不正常,可以改成如这样判断:where (name is null)
(4)真假值判断:access中可以用=true、=false来判断,但是在SQL中就会出错,因此在SQL查询或执行语句中这类判断要分别改成=1、=0。注意一点:有些程序虽然写成=“true”,但是由于有引号,所以这个字段是字符类型的,你不能改成=1,保持原样即可。

/ |* h. n7 C2 S7 s# \5 x( I0 N

  以上是比较常见的改写的地方,还有一些不太常见,如果遇到了可以在此回帖讨论。

5 d [0 q, I' ^

五、程序的调试

8 X1 T( X! z: q0 d) z- F) a

  前面推荐使用带有行号的编辑器,是因为上述的改写不大可能是直接搜索程序源码来做,很难找全。
  我采取的方式一般这样:数据库改写完成,直接调试程序,出错后,看看出错的提示,找到相应文件的代码行,但是根源往往不是那行,比如出错的语句是:conn.execute(sql),但是这句本身是没有错的,错误原因是里面的这个sql字符串,那就向上看这个sql字符串是如何生成的,按照上面所说的程序修改办法修改。

]$ B1 k; ? M. ?/ m3 ~; J$ d7 r

数据库导入以后,自动增加字段需要重写,所有的数字类型需要增加长度,最好用decimal。

, c2 a, D. M/ [' [8 ]

所有的默认值都丢失了。主要是数字类型和日期类型。

! ^* u( y/ [. v, G* g

所有now(),time(),date()要改成getdate()。
所有datediff('d', time1, time2)要改成datediff(day, time1, time2)
有可能一些true/false类型不能使用,要变为1/0。
备注类型要通过cast(column as varchar)来使用。
CursorType要改成1,也就是打开数据库时要给出第

 
 楼主| 乐将秘书 发表于 2009-8-25 17:11:03 | 显示全部楼层
 
一个数字参数为1,否则记录可能显示不完整。
isnull(rowname)要改成rowname = null ) n1 Y& i! L& c/ V( h

, b# B2 {. a( X3 N9 }7 u% B

ACCESS的数据库中的自动编号类型在转化时,sql server并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号!
转化时,跟日期有关的字段,SQL SERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。有时用smalldatetime型时,转化失败,而用datetime型时,转化成功。
对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:"delete * from user where id=10",而对SQL SERVER数据库进行删除是用:"delete user where id=10".
日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对SQL SERVER数据库处理中,只能用datediff,dateadd等函数,而不能用date()、time()等函数。
在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQL SERVER数据库处理中,却不能用。
下表比较了MicrosoftAccess数据库(MicrosoftAccess数据库:数据和对象(如表、查询或窗体)组成的集合,与特定的主题或用途有关。MicrosoftJet数据库引擎用于管理数据。)和MicrosoftAccess项目(MicrosoftAccess项目:与MicrosoftSQLServer数据库连接且用于创建客户/服务器应用程序的Access文件。项目文件中不包含任何数据或基于数据定义的对象(如表或视图)。)的数据类型(数据类型:决定字段可拥有的数据类型的字段特征。数据类型包括Boolean、Integer、Long、Currency、Single、Double、Date、String和Variant(默认))。

. z* ^' H0 {$ P2 s

MicrosoftAccess数据类型SQLServer数据类型
是/否(“是/否”数据类型:一种字段数据类型,用于只有两种可能值(如是或否、True或False)的字段。不允许有Null值。)bit(bit数据类型:在Access项目中,一种存储值为1或0的数据类型。接受1和0以外的整数值,但总是将其解释为1。)
数字(“数字”数据类型:MicrosoftAccess数据库中的一种字段数据类型,用于将在数学运算中使用的数值数据。但是,若要显示或计算货币值,则应使用“货币”数据类型。)(字节)tinyint(tinyint数据类型:Access项目中的一种占一个字节(8位)的数据类型,用于存储从0到255范围内的整数。)
数字(整型)smallint(smallint数据类型:Access项目中的一种2字节(16位)数据类型,存储位于-2^15(-32,768)与2^15-1(32,767)之间的数字。)
数字(长整型)int(int数据类型:Access项目中的一种4字节(32位)数据类型,存储位于-2^31(-2,147,483,648)与2^31-1(2,147,483,647)之间的数字。)
数字(单精度浮点型)real(real数据类型:在Access项目中,一种近似的数值数据类型,精度为6位,正值取值范围大致从1.18E-38到3.40E+38,负值取值范围大致从-1.18E-38到-3.40E+38,也可以取0。)
(无等价的数据类型)bigint(bigint数据类型:Access项目中的一种8字节(64位)数据类型,存储位于-2^63(-9,223,372,036,854,775,808)与2^63-1(9,223,372,036,854,775,807)之间的数字。)
数字(双精度浮点型)float(float数据类型:在Access项目中,一种近似的数值数据类型,精度为15位。它所存储的正值范围大致是从2.23E-308到1.79E+308,负值范围大致是从-2.23E-308到-1.79E+308,也可以为0。)
货币(“货币”数据类型:MicrosoftAccess数据库中的一种数据类型,用于与货币有关的计算或其精确度极其重要的定点计算。)money(money数据类型:在Access项目中,用于存储货币值的数据类型,取值范围从-922,337,203,685,477.5707到922,337,203,685,477.5807,精确度为万分之一个货币单位。)

7 L0 P% J% V0 M, h, g' {; c

smallmoney(smallmoney数据类型:Access项目中的一种存储货币值的数据类型,取值范围从-214,748.3648到214,748.3647,精确度为万分之一个货币单位。当显示smallmoney值时,会将它们四舍五入为两个小数位。)
小数/数值(decimal数据类型(Access数据库):精确的数值数据类型,用于存储-10^38-1到10^38-1的值。可以指定数值范围(最大总位数)和精度(小数点右边的最大位数)。)decimal(decimal数据类型(Access项目):精确的数值数据类型,用于存储-10^38-1到10^38-1的值。可以指定数值范围(最大总位数)和精度(小数点右边的最大位数)。)

# ?- |$ v: f) d( T- x0 x

numeric(numeric数据类型:在Access项目中,一种精确的数值数据类型,取值从-10^38-1到10^38-1。可以指定数值范围(最大总位数)和精度(小数点右边的最大位数)。)
日期/时间(“日期/时间”数据类型:Access数据库的一种数据类型,用来存放日期和时间信息。)datetime(datetime数据类型:在Access项目中,日期和时间的数据类型,范围从1753年1月1日到9999年12月31日,精确度为三百分之一秒,即3.33毫秒。)

0 G; n4 s7 B/ B! _- f

smalldatetime(smalldatetime数据类型:Access项目中的一种日期和时间数据类型,精度不如da

 
 楼主| 乐将秘书 发表于 2009-8-25 17:11:15 | 显示全部楼层
 
tetime时间数据类型。数据取值范围从1900年1月1日到2079年6月6日,精确度为一分钟。)
自动编号(“自动编号”数据类型:MicrosoftAccess数据库中的一种字段数据类型,当向表中添加一条新记录时,这种数据类型会自动为每条记录存储一个唯一的编号。可以产生三种编号:顺序号、随机号和同步复制ID。)(递增)int(int数据类型:Access项目中的一种4字节(32位)数据类型,存储位于-2^31(-2,147,483,648)与2^31-1(2,147,483,647)之间的数字。)(定义了Identity属性)
文本(“文本”数据类型:MicrosoftAccess数据库中的一种字段数据类型。“文本”数据类型最多可以包含255个字符,或者是由FieldSize属性指定的一个小一些的字符数。)(n)varchar(n)(varchar(n)数据类型:Access项目中的一种可变长度的数据类型,最大长度为8,000个ANSI字符。) $ P7 e( q# ~6 M) H. i R

* ]( m2 a' b; q3 r

nvarchar(n)(nvarchar(n)数据类型:在Access项目中,一种可变长度的数据类型,最多可含4,000个Unicode字符。Unicode字符每字符占两个字节,而且支持所有国际字符。)
备注(“备注”数据类型:在MicrosoftAccess数据库中的一种字段数据类型。“备注”字段最多可以包含65,535个字符。)text(text数据类型:Access项目中的一种长度可变的数据类型,最多可存储2^31-1(2,147,483,647)个字符;默认长度为16。)
OLE对象(“OLE对象”数据类型:字段的数据类型之一,用于在其他应用程序中创建的、可链接或嵌入(插入)到Access数据库中的对象。)image(image数据类型:在Access项目中,一种长度可变的数据类型,最多可存储2^31-1(2,147,483,647)字节的二进制数据。image数据类型用来存储BLOB(二进制大对象),如图片、文档、声音和已编译代码。)
同步复制ID(又名全局唯一标识符(GUID:在Access数据库中,一种用于建立同步复制唯一标识符的16字节字段。GUID用于标识副本、副本集、表、记录和其他对象。在Access数据库中,GUID是指同步复制ID。)(GUID))uniqueidentifier(uniqueidentifier数据类型:在Access项目中,16字节的全局唯一标识符(GUID)。)(仅适于SQLServer7.0或更高版本)
超链接(“超链接”数据类型:存储超链接地址的Access数据库字段的数据类型。地址最多可以包含四部分,用以下语法格式编写:displaytext#address#subaddress#。)char(char数据类型:在Access项目中,一种固定长度的数据类型,最多可含8,000个ANSI字符。),

: a& D7 i0 {9 n' |5 I* r( b7 c

nchar(nchar数据类型:在Access项目中,一种固定长度的数据类型,最多可含4,000个Unicode字符。Unicode字符每字符占两个字节,而且支持所有国际字符。),varchar,nvarchar(Hyperlink属性设为Yes)
(无等价的数据类型)varbinary(varbinary数据类型:Access项目中的一种可变长度的数据类型,最多可存储8,000字节的二进制数据。)
(无等价的数据类型)smallint(smallint数据类型:Access项目中的一种2字节(16位)数据类型,存储位于-2^15(-32,768)与2^15-1(32,767)之间的数字。)
(无等价的数据类型)timestamp(timestamp数据类型:在Access项目中,一种每插入或更新一行就会自动更新的数据类型。timestamp列中的值不是datetime数据,而是binary(8)或varbinary(8),标明了数据修改的顺序。)
(无等价的数据类型)charnchar
(无等价的数据类型)sql_variant(sql_variant数据类型:Access项目中的一种数据类型,存储除text、ntext、image、timestamp和sql_variant类型以外的多种数据类型的值。在列、参数、变量或用户定义函数的返回值中使用。)
(无等价的数据类型)用户定义(用户定义的数据类型:在MicrosoftSQLServer数据库中,允许某列包含的数据的类型定义,由用户利用现有的系统数据类型定义。规则和默认值仅可以绑定到用户定义的数据类型。)

# x; {% ~) J9 E2 r1 f

注释在Access项目或SQLServer数据库中,前缀“n”代表“国家/地区”,意思是这个数据类型是启用Unicode的。在Access数据库中,全部文本列在默认情况下都是启用Unicode的。
ACCESS转SQL需要注意的问题
2006-2-13 16:01:20
很多朋友想用SQL2000数据库的编程方法,但是却又苦于自己是学ACCESS的,对SQL只是一点点的了解而已,这里我给大家提供以下参考---将ACCESS转化成SQL2000的方法和注意事项
一,首先,我说的是在ACCESS2000,SQL2000之间转换,其他的我也还没有尝试过,希望大家多多试验,肯定是有办法的;
二,转换的方法
1,打开”控制面板“下”管理工具“中的”数据库源“;
2,按”添加“添加一个新的数据源,在选择栏里选”DriverdomicrosoftAccess
(*.mdb)”,完成后将出现一个框,

`, p) d- w: N W2 _6 }2 }3 ?

在”数据库源“里面输入你想写的名称,我取名叫“ABC”,说明不需要填,接着,按下面的选择,寻找你的数据库地址和选中(注意,请先备份自己的ACCESS数据库),然后确定。
数据源在这里建好了,剩下转换了。

) k/ |5 f+ c8 {+ n/ y

3,打开SQL2000企业管理器,进入数据库,新建一个空的数据库“ABC”;
4,选择

 
 楼主| 乐将秘书 发表于 2009-8-25 17:11:27 | 显示全部楼层
 
新建立的数据库,按鼠标右键,选择“所有任务”下“导入数据”,按“下一步”继续;
5,在数据库源下拉但中选择”DriverdomicrosoftAccess(*.mdb)“,在”用户/系统DSN“中,选种你刚才添加的”ABC“,按”下一步“;
6,“目的”不需要修改,选择服务器(一般下为自己的本机"local",也可以选择服务器地址或者局域网地址,确定你的权限是否可以操作,),"使用WINDOWS身份验证"指用自己的系统管理员身份操作,"使用SQL身份操作验证"可以用于网站的操作,推荐用后者;
7,选上"使用SQL身份操作验证"后,填写你的用户名和密码,我自己选择的是系统默认号码"sa","****",数据库选择刚新建的"ABC",按"下一步";
8,这一步的两个单项选择,"从数据源复制表和视图"与"用一条查询指令指定要传输的数据",选择前者,按"下一步"继续;
9,这里将出现你自己ACCESS数据库的表,按"全选"后,下一步;
10,"DTS导入/导出向导",看"立即运行"被选中按"下一步",
11,按"完成"继续;
12,这个步骤你将看到你的数据被导入SQL2000里面,当出现"已经成功把XXX个表导入到数据库"的字样,而且所有的表前面都有绿色的勾,就表示成功导入所有数据,如果中途出现问题或者表前面有红色的*的话,说明该表没有成功导入,这时就要回去查看自己的操作是否正确了. 5 a1 n8 w& k# S- n' ?

, v2 ~! y9 `# y: a

三,数据修改
1,由于SQL2000里面没有"自动编号",所以你的以"自动编号"设置的字段都会变成非空的字段,这就必须手工修改这些字段,并把他的"标示"选择"是",种子为"1",增量为"1",
2,另外,ACCESS2000转换成SQL2000后,原来属性为"是/否"的字段将被转换成非空的"bit",这时候你必须修改成自己想要的属性了;
3,另外,大家要注意对时间函数的把握.ACCESS与SQL是有很多不同的.

+ l) C6 x* D6 w; \# V$ B( e


四、相关的字段问题
1.ACCESS的数据库中的自动编号类型在转化时,sqlserver并没有将它设为自动编号型,我们需在SQL创建语句中加上identity,表示自动编号!
2.转化时,跟日期有关的字段,SQLSERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。我遇见这种情况,用smalldatetime型时,转化失败,而用datetime型时,转化成功。
3.对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:"delete*fromuserwhereid=10",而对SQLSERVER数据库进行删除是用:"deleteuserwhereid=10".
4.日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对SQLSERVER数据库处理中,只能用datediff,dateadd等函数,而不能用date()、time()等函数。
5.在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQLSERVER数据库处理中,却不能用。

" F) [6 u& |4 w) K M

五、相关语句问题
自动增加字段需要重写。在access中经常使用的自动编号字段,导入到mssql后,他并不是自增型的int,需要手工设置,把导入后的自动编号字段的标识的“否”改为“是”,“种子”和“递增量”都为“1”,才能成为自动编号

3 |; F7 `' s. Q


所有的默认值都丢失了。主要是数字类型和日期类型
所有now(),time(),date()要改成getdate()
所有datediff('d',time1,time2)要改成datediff(day,time1,time2)
所有datediff('ww',time1,time2)要改成datediff(week,time1,time2)
所有datediff('d',time1,time2)要改成datediff(day,time1,time2)
在mssqlserver中,有许多保留字,在access中是没有的,当你把数据导入到mssql的时候,问题就出来了。mssql在导入的时候,会自动给这些字段(包括数据库中的表名)加上“[字段名]”,因此,你必须修改你的脚本,把相应的字段名字(或者表名字)加上中括号,或改变字段名字为不是mssql的保留字
在用access关于时间的使用,大家喜欢使用“select*fromaaaawhiletime="&now()”这样的sql语句,然而,在mssql中没有“now()”这个函数,而是使用“getdate()”,所以,所有的sql语句中的“now()”必须换成“getdate()”。
日期函数不相同,在对ACCESS数据库处理中,可用date()、time()等函数,但对
SQLSERVER数据库处理中,只能用datediff,dateadd等函数,而不能用date()、time()等函数。
转化时,跟日期有关的字段,SQLSERVER默认为smalldatetime型,我们最好将它变为datetime型,因为datetime型的范围比smalldatetime型大。有时用smalldatetime型时,转化失败,而用datetime型时,转化成功
isnull(rowname)要改成rowname=null
CursorType要改成1,也就是打开数据库时要给出第一个数字参数为1,否则记录可能
显示不完整
备注类型要通过cast(columnasvarchar)来使用
true/false类型不能使用,要变为1/0
对此两种数据库进行操作的sql语句不全相同,例如:在对ACCESS数据库进行删除纪录时用:"delete*fromuserwhereid=10",而对SQLSERVER数据库进行删除是用:"deleteuserwhereid=10".
在对ACCESS数据库处理中,sql语句中直接可以用一些VB的函数,像cstr()函数,而对SQLSERVER数据库处理中,

 
 楼主| 乐将秘书 发表于 2009-8-25 17:11:38 | 显示全部楼层
 
却不能用
在access的sql语句中的时间使用变量查询的时候,大家一般使用"select*fromaaaawhiletime=#"&变量名&"#",在mssql中是不行的,他的语法是“select*fromaaaawhiletime='"&变量名&"'"”。(意思是让你把日期时间变量当成字符串来使用,呵呵~~~)
原来ASP里的“Delete*FROM……”要改为“DeleteFROM……”
有可能rs.update失败,修改成update表名set字段=‘值’这样通过(遇到的情况,提示为:
MicrosoftOLEDBProviderforSQLServer错误'80040e38'
乐观并发检查失败。已在此游标之外修改了该行。
/Admin_ClassOrder.asp,行164)
access里面除法可以使用"\"或者"/",MSSQL里面只能使用"/" 7 e8 p$ `3 B( N: ]- j' L

+ J% K' G2 g, m, L3 `9 F, ^

 

 
 楼主| 乐将秘书 发表于 2009-8-25 17:30:33 | 显示全部楼层
 

SQL语句CAST()在操作access的时候对应使用cint函数

4 Q& f$ Q1 C: d& k

============================================

0 K$ x3 i) U( R' I; f/ D

CInt 函数
返回表达式,此表达式已被转换为 Integer 子类型的 Variant。

3 \' C2 T, y5 |3 e' B9 Z! H v

CInt(expression)

* v1 W* P0 D/ k; j+ c

expression 参数是任意有效的表达式。

! P3 J- d' w/ z1 Z2 [; G, G2 t

说明
通常,可以使用子类型转换函数书写代码,以显示某些操作的结果应被表示为特定的数据类型,而不是默认类型。例如,在出现货币、单精度或双精度运算的情况下,使用 CInt 或 CLng 强制执行整数运算。

3 I' W& e' o, c' S8 ^& Q" b

CInt 函数用于进行从其他数据类型到 Integer 子类型的国际公认的格式转换。例如对十进制分隔符(如千分符)的识别,可能取决于系统的区域设置。

6 b1 L1 r' U2 x4 B

如果 expression 在 Integer 子类型可接受的范围之外,则发生错误。

, n& g3 Y5 e$ w! w3 _

下面的示例利用 CInt 函数把值转换为 Integer:

& X0 P, O2 J( X* H/ H) W' D

Dim MyDouble, MyInt
MyDouble =2345.5678 ' MyDouble 是 Double。
MyInt =CInt(MyDouble) ' MyInt 包含 2346。
注意 CInt 不同于 Fix 和 Int 函数删除数值的小数部分,而是采用四舍五入的方式。 当小数部分正好等于 0.5 时, CInt 总是将其四舍五入成最接近该数的偶数。例如, 0.5 四舍五入为 0, 以及 1.5 四舍五入为 2.

( [: E4 D7 A. Q' p+ b6 Z, Z7 R

=================================================

: r- Z- b/ j4 q. ~8 e$ `

类型转换函数
     

; k- @7 u6 w/ }

每个函数都可以强制将一个表达式转换成某种特定数据类型。

+ ~! K6 g* ~; ~/ Z' A* p* s+ ]

语法
CBool(expression)

7 P' X/ P) j: T

CByte(expression)

2 m* L: L) ?, |# g' C" E: N6 h

CCur(expression)

T7 }1 a- L' `! C. N

CDate(expression)

e0 y( U5 Y# U0 y6 X8 j# c) V

CDbl(expression)

5 \, E7 A3 G8 D! b- |+ W

CDec(expression)

/ @2 `; I; {' F% P/ K: }: g# \

CInt(expression)

, p0 Q l; }' }0 l7 N

CLng(expression)

* [# r8 f( R8 u0 H' y. Q, ~+ Y

CSng(expression)

) f7 u2 B7 _$ t

CStr(expression)

& e; h3 }3 s0 |! s8 I/ \

CVar(expression)

5 L& O0 x9 Y1 D- }

CStr(expression)

# Y+ r6 v8 e+ V/ g

必要的 expression 参数可以是任何字符串表达式或数值表达式。

1 ^) K- w G+ M* j0 p; X

返回类型
函数名称决定返回类型,如下所示:

+ Z3 K1 ^$ C$ Z% R) y# [: N! x- Z1 F

函数 返回类型 expression 参数范围
CBool Boolean 任何有效的字符串或数值表达式。
CByte Byte 0 至 255。
CCur Currency -922,337,203,685,477.5808 至922,337,203,685,477.5807。
CDate Date 任何有效的日期表达式。
CDbl Double 负数从 -1.79769313486231E308 至 -4.94065645841247E-324;正数从 4.94065645841247E-324 至 1.79769313486232E308。

 
 楼主| 乐将秘书 发表于 2009-8-25 17:30:48 | 显示全部楼层
 
CDec Decimal 零变比数值,即无小数位数值,为
+/-79,228,162,514,264,337,593,543,950,335。对于 28 位小数的数值,范围则为
+/-7.9228162514264337593543950335;最小的可能非零值是 0.0000000000000000000000000001。
CInt Integer -32,768 至 32,767,小数部分四舍五入。
CLng Long -2,147,483,648 至 2,147,483,647,小数部分四舍五入。
CSng Single 负数为 -3.402823E38 至 -1.401298E-45;正数为 1.401298E-45 至 3.402823E38。
CStr String 依据 expression 参数返回 Cstr。
CVar Variant 若为数值,则范围与 Double 相同;若不为数值,则范围与 String 相同。 0 O/ {8 e! }( U" _

: G2 T& W- @/ g6 h% x: c

说明
如果传递给函数的 expression 超过转换目标数据类型的范围,将发生错误。

% ]+ A% F. b" { ~: z) n* C( i

通常,在编码时可以使用数据类型转换函数,来体现某些操作的结果应该表示为特定的数据类型,而不是缺省的数据类型。例如,当单精度、双精度或整数运算发生的情况下,使用 CCur 来强制执行货币运算。

) Z: y7 q, g2 x' j: Y

应该使用数据类型转换函数来代替 Val,以使国际版的数据转换可以从一种数据类型转换为另一种。例如,当使用 Ccur 时,不同的小数点分隔符、千分位分隔符和各种货币选项,依据系统的区域设置都会被妥善识别。

& q& n4 ?0 E8 B! @$ m

当小数部分恰好为 0.5 时,Cint 和 CLng 函数会将它转换为最接近的偶数值。例如,0.5 转换为 0、1.5 转换为 2。Cint 和 CLng 函数不同于 Fix 和 Int 函数,Fix 和 Int 函数会将小数部分截断而不是四舍五入。并且 Fix 和 Int 函数总是返回与传入的数据类型相同的值。

& ^. z1 ^( x i7 b, h

使用 IsDate 函数,可判断 date 是否可以被转换为日期或时间。Cdate 可用来识别日期文字和时间文字,以及落入可接受的日期范围内的数值。当转换一个数字成为日期时,是将整数部分转换为日期,小数部分转换为从午夜起算的时间。

7 l( e% I" R3 L2 |3 B: f

CDate 依据系统上的区域设置来决定日期的格式。如果提供的格式为不可识别的日期设置,则不能正确判断年、月、日的顺序。另外,长日期格式,若包含有星期的字符串,也不能被识别。

% x3 q. k$ a- K0 w

CVDate 函数也提供对早期 Visual Basic 版本的兼容性。CVDate 函数的语法与 CDate 函数是完全相同的,不过,CVDate 是返回一个 Variant,它的子类型是 Date,而不是实际的 Date 类型。因为现在已有真正的 Date 类型,所以 CVDate 也不再需要了。转换一个表达式成为 Date,再赋值给一个 Variant,也可以达到同样的效果。也可以使用这种技巧将其他真正的数据类型转换为对等的 Variant 子类型。

/ D# z% s* h- u5 ^

注意 CDec 函数不能返回独立的数据类型,而总是返回一个 Variant,它的值已经被转换为 Decimal 子类型

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

本版积分规则


0关注

0粉丝

271帖子

排行榜
作者专栏

关注我们:微信订阅号

官方微信公众号

客服个人微信号

全国服务热线:

0595-22880819

公司地址:泉州秘途文化传媒有限公司

运营中心:福建省泉州市

Email:506070961#qq.com

Copyright   ©2015-2025  老秘网 责任编辑:释然Powered by©Discuz!技术支持:秘途文化  备案号   ( 闽ICP备19022590号-1 闽公网安备35050302000919号 )