Access转Sql Server问题 实例说明

所属分类: 数据库 / Access 阅读数: 1556
收藏 0 赞 0 分享
今天帮同学改一个老的系统作为毕业设计,这系统技术绝对落后asp+access。为了应付老师的验收,然后这同学编程又不是很好,而其到了最后时刻才想到开始做毕设,于是找到了我。

我看了他不知从哪里搞来的代码,跑了下,还行能跑,过两天就要验收程序了,把asp改成 asp.net是没时间了,于是我提议改下数据库算了,于是决定把access转成sql server。看似一个公司的产品,转起来问题到一大堆。现总结如下,

先说怎么转移数据,打开sqlserver的企业管理器,建立张表,然后右击那张表,点导入数据,然后选中数据源(我这里就是access的mdb文件),一路next,基本没什么问题,数据就这样导好了,但问题没那么简单,sql server和access的机制有很大的不同

1,由于SQL2000里面没有自动编号,所以你的以自动编号设置的字段都会变成非空的字段,这就必须手工修改这些字段,并把他的标示选择是,种子为1,增量为1,

2,另外,ACCESS2000转换成SQL2000后,原来属性为是/否的字段将被转换成非空的bit,这时候你必须修改成自己想要的属性了;

3,另外,大家要注意对时间函数的把握.ACCESS与SQL是有很多不同的.

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

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数据库处理中,却不能用。
更多精彩内容其他人还在看

中文Access2000速成教程--1.2 使用“数据库向导”创建表

中文Access2000速成教程--1.2 使用“数据库向导”创建表
收藏 0 赞 0 分享

建立自由的会计日期的报表--1.2.创建让用户选择日期窗体

建立自由的会计日期的报表--1.2.创建让用户选择日期窗体
收藏 0 赞 0 分享

建立自由的会计日期的报表--1.1.认识几个有关时间的函数

建立自由的会计日期的报表--1.1.认识几个有关时间的函数
收藏 0 赞 0 分享

建立自由的会计日期的报表

建立自由的会计日期的报表
收藏 0 赞 0 分享

使用准则进行条件查询--1.5.常用的准则表达式

使用准则进行条件查询--1.5.常用的准则表达式
收藏 0 赞 0 分享

使用准则进行条件查询--1.4.从窗体中选择查询的条件

使用准则进行条件查询--1.4.从窗体中选择查询的条件
收藏 0 赞 0 分享

中文Access2000速成教程--1.1 使用“向导”设计数据库

中文Access2000速成教程--1.1 使用“向导”设计数据库
收藏 0 赞 0 分享

获取ACCESS2000数据库中所有表的名称

获取ACCESS2000数据库中所有表的名称
收藏 0 赞 0 分享

中文Access2000速成教程--1.3 在“设计”视图中设计表

中文Access2000速成教程--1.3 在“设计”视图中设计表
收藏 0 赞 0 分享

中文Access2000速成教程--1.4 使用“表向导”建立新表

中文Access2000速成教程--1.4 使用“表向导”建立新表
收藏 0 赞 0 分享
查看更多