这几天做了一个程序,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 连存储过程都不支持,微软,想说爱你并不容易。
新闻热点
疑难解答