日期:2014-01-21  浏览次数:20517 次

这几天做了一个程序,VS 2005 + SQL Server Express,细心查阅文档,发现 SQL Server Express 支持 XCOPY 部署方式,也就是说,只需目标计算机有了 SQL Server Express,那么只需求把数据库拷贝过去,可以在程序的同一个目录中,然后在连接字符串中配置 AttachDBFileName 参数即可。数据库会自动挂接到 SQL Server Express 中,运转完后自动 Deattch。感觉不错,照猫画虎,结果出现了一个错误:“数据库已被紧缩,无法建立,需求解紧缩”。晕死,什么时候紧缩了?莫非是 Shinrk 的问题?搞了 n 个小时,无解,睡觉。
   
次日再战,查阅材料无解,查阅 Internet 无解,想放弃,又舍不得。无意中发现,在管理界面中 Attach 数据库竟然也是这个错误,而在原先目录中的数据库竟然没问题。把数据库拷贝到程序目录(在 D: 盘,SQL Server Express 安装在 C: 盘)就会出错。不会是这个问题吧?
   
将程序目录挪动到 C 盘,竟然一切正常,然后彻底晕死。难道自动挂接数据库必须在 C 盘???
   
另,如果将数据库文件设置为只读,则无论在哪个盘都可挂接,只是成为只读数据库。
   
虽说处理了问题,可是不懂原理,是 Bug,还是我的系统问题?
   
其实,Sybase 的 SQL Anywhere 真的不错,在启动数据库的时候才启动数据库管理系统,系统运转结束,数据库管理系统自动结束,如果 SQL Server Express 也支持这个功用就好了,我可不喜欢不用数据库的时候还有一个 SQL Server 服务在运转。Access 连存储过程都不支持,微软,想说爱你并不容易。