最近,一客户遇到一个奇怪的问题,sqlserver数据库,使用备份恢复到目标机器。之后,在目标服务器创建了测试函数对象,但是执行查询的时候却提示对象不存在,再次尝试重新创建该函数及其依赖的对象时能正常执行。经过仔细检查发现登陆操作的用户拥有的默认架构是db_owner,检查创建的数据库下的相关函数显示db_owner.func_name,当查询语句引用对象加上db_owner.func_name时可以执行正常执行查询。后来在创建函数及其依赖的对象时加上dbo.func_name,再次执行查询可以正常执行。
一、问题现象
在sqlserver数据库中创建了测试函数对象,但是执行查询的时候却提示对象不存在:
再次尝试重新创建该函数及其依赖的对象时,没有发现任提示报错:
二、问题分析
查看指定数据库下该函数的位置情况,发现其在db_owner下:
尝试执行select * from db_owner.Fn_GetQuestion……能正常执行查询:
后经过查看执行操作的用户的默认架构是db_owner。
三、问题处理
将函数及其依赖的对象删除,在对象名称前添加dbo.前缀后再次执行创建,程序测试查询恢复正常。
四、总结
sqlserver数据库与其他数据库不一样,其数据库对象默认存放在dbo方案下,程序执行解析时也是默认在dbo方案下查找,当类似本案例的函数或者表对象创建没有添加dbo.前缀时,创建的对象就可能放在其他方案下,导致程序执行解析出现异常。
因此,使用sqlserver数据库时,创建表或者函数等对象,最好养成显示添加dbo.前缀。