如何解决“SQL对象名无效”的问题
创始人
2024-07-29 07:10:32
0

今天遇到一个让人不淡定的问题.

网站升级后,打开一个页面无法访问, 提示: “对象名”xxx”无效.

xxx表在服务器上没有创建,于是俺打开 “sql查询分析器”:

导出创建xxx表的sql脚本,如下:

  1. CREATE TABLE [xxx] (  
  2. [id] [int] IDENTITY (1, 1) NOT NULL ,  
  3. [title] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  4. [kind] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  5. [content] [nvarchar] (1000) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  6. [keyword] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  7. [Add_Date] [datetime] NULL 
  8. ) ON [PRIMARY] 

然后在服务器上创建. 再次刷新, 提示: 对象名”xxx”无效. 香蕉你个扒拉~~

Google上搜索, 可能的原因是 数据库所有者问题. 数据库可以有不同的登陆帐户,

而数据库是可以隶属于某个帐户的, 于是问题就出来了.

假若在pubs库中logina帐户登陆并创建一个x表, 然后loginb帐户登陆并查询x表

就提示: 对象名”xxx”无效.

我勒你个去!~

以下省略N个

鬼知道刚才那个脚本将表创建到那个用户下了. 于是,聪明的我又打开”企业管理器”,

选中表 导出sql脚本,这次出来的脚本就带上 所有者了:

  1. CREATE TABLE [logina].[xxx] (  
  2. [id] [int] IDENTITY (1, 1) NOT NULL ,  
  3. [title] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  4. [kind] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  5. [content] [nvarchar] (1000) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  6. [keyword] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  7. [Add_Date] [datetime] NULL 
  8. ) ON [PRIMARY]  
  9. GO 

于是俺drop table 服务器上的 xxx 表,又运行了上面的脚本.

再次刷新, 娘西匹! 还是:对象名”xxx”无效.

我数据库访问层使用的是subsonic, 于是我就看了subsonic生成的代码,发现有这样

一行:

  1. schema.SchemaName = @"dbo"; 

哇! 可俺数据库连接字符串中的登陆名不是这个玩意儿啊!

但是, 其他的表貌似查询啥的都无问题??????????????????????????????

于是,俺在服务器上运行的代码中加了如下一行:

  1. output q.BuildSqlStatement(); 

俺直接将生成的查询代码在服务器上运行,提示: 对象名”xxx”无效.

我日,有门~!

因为生成的脚本中,xxx表前加的所有者是”dbo”. 我靠~

再次, drop table xxx, 然后:

  1. CREATE TABLE [dbo].[xxx] (  
  2. [id] [int] IDENTITY (1, 1) NOT NULL ,  
  3. [title] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  4. [kind] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  5. [content] [nvarchar] (1000) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  6. [keyword] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,  
  7. [Add_Date] [datetime] NULL 
  8. ) ON [PRIMARY]  
  9. GO 

再次刷新, 可爱的小姑娘到底还是害羞的走了出来.~~~

总结:

1,在真实的生产环境中,需要注意 表所有者的问题.

2,不同的所有者创建的表,在其他用户登录下是访问不到的,会提示: 对象名”xxx”无效.

3,为啥我的登陆名是 logina 但加上logina却提示: 对象名”xxx”无效? 因为subsonic

生成的脚本使用的是 dbo. 为什么? 鬼知道~~

原文链接:http://www.cnblogs.com/andysunndy/archive/2011/05/16/2047514.html

【编辑推荐】

  1. 浅述远程Service Broker的实现
  2. Service Broker基础应用(下)
  3. Service Broker基础应用(上)
  4. 告诉你如何解决MySQL server has gone away问题
  5. SQL使用中的点滴回忆

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...