我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQLServer 错误 4104 无法绑定由多个部分组成的标识符 “%.*ls”。 故障 处理 修复 支持远程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQLServer 错误 4104 无法绑定由多个部分组成的标识符 “%.*ls”。 故障 处理 修复 支持远程

详细信息

Attribute
产品名称 SQL Server
事件 ID 4104
事件源 MSSQLSERVER
组件 SQLEngine
符号名称 ALG_MULTI_ID_BAD
消息正文 无法绑定由多个部分组成的标识符 “%.*ls”。

说明

SQL Server 中实体的名称称为其“标识符”。 在引用实体(例如在查询中指定列名和表名)时可以使用标识符。 由多个部分组成的标识符包含一个或多个作为标识符前缀的限定符。 例如,表标识符可能以诸如包含表的数据库和架构的名称之类的限定符作为前缀,而列标识符可能以诸如表名称或表别名之类的限定符作为前缀。

错误 4104 表示无法将指定的由多个部分组成的标识符映射到现有实体。 在以下情况下可能会返回此错误:

  • 作为列名称前缀提供的限定符与查询中使用的任何表名或别名均不对应。

    例如,下面的语句使用表别名 (Dept) 作为列前缀,但是此表别名未在 FROM 子句中引用。

    SELECT Dept.Name FROM HumanResources.Department;  
    

    在下面的语句中,在属于两个表之间的 JOIN 条件的 WHERE 子句中指定了由多个部分组成的列标识符 TableB.KeyCol,但是 TableB 未在查询中显式引用。

    DELETE FROM TableA WHERE TableA.KeyCol = TableB.KeyCol;  
    
    SELECT 'X' FROM TableA WHERE TableB.KeyCol = TableA.KeyCol;  
    
  • 在 FROM 子句中提供了表的别名,但为列提供的相应限定符却是表名称。 例如,下面的语句使用表名称 Department 作为列前缀,但是,在 FROM 子句中引用的是表别名 (Dept)。

    SELECT Department.Name FROM HumanResources.Department AS Dept;  
    

    使用别名时,不能在语句中的其他地方使用表名称。

  • SQL Server 无法确定由多个部分组成的标识符是指由表作为前缀的列,还是指由列作为前缀的 CLR 用户定义数据类型 (UDT) 的属性。 出现这种情况的原因是:UDT 列的属性是通过在列名称和属性名称之间使用句号分隔符 (.) 引用的,而这与用表名称作为列名称前缀的方式相同。 以下示例创建两个表:ab。 表 b 包含列 a,此列使用 CLR UDT dbo.myudt2 作为其数据类型。 SELECT 语句包含由多个部分组成的标识符 a.c2

    CREATE TABLE a (c2 int);   
    GO  
    
    CREATE TABLE b (a dbo.myudt2);   
    GO  
    
    SELECT a.c2 FROM a, b;   
    

    假定 UDT myudt2 不具有名为 c2 的属性,则 SQL Server 将无法确定标识符 a.c2 是指表 a 中的列 c2,还是指表 b 中的列 a、属性 c2

用户操作

  • 使列前缀与在查询的 FROM 子句中指定的表名或别名相匹配。 如果在 FROM 子句中为表名称定义了别名,则只能将此别名用作与该表关联的列的限定符。

    上面引用 HumanResources.Department 表的语句可以进行如下更正:

    SELECT Dept.Name FROM HumanResources.Department AS Dept;  
    GO  
    
    SELECT Department.Name FROM HumanResources.Department;  
    GO  
    
  • 确保在查询中指定所有表,并确保正确地指定表之间的 JOIN 条件。 上面的 DELETE 语句可以进行如下更正:

    DELETE FROM dbo.TableA  
    WHERE TableA.KeyCol = (SELECT TableB.KeyCol   
                            FROM TableB   
                            WHERE TableA.KeyCol = TableB.KeyCol);  
    GO  
    

    上面 TableA 的 SELECT 语句可以进行如下更正:

    SELECT 'X' FROM TableA, TableB WHERE TableB.KeyCol = TableA.KeyCol;  
    

    SELECT 'X' FROM TableA INNER JOIN TableB ON TableB.KeyCol = TableA.KeyCol;  
    
  • 为标识符使用明确定义的唯一名称。 这样做可以使您的代码更易于理解和维护,并可以将不明确引用多个实体的风险降至最低。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQLServer 错误 4104 无法绑定由多个部分组成的标识符 “%.*ls”。 故障 处理 修复 支持远程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQLServer 错误 4104 无法绑定由多个部分组成的标识符 “%.*ls”。 故障 处理 修复 支持远程

详细信息 Attribute 值 产品名称 SQL Server 事件 ID 4104 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 ALG_MULTI_ID_BAD 消息正文 ...
SQLServer 错误 4104 无法绑定由多个部分组成的标识符 “%.*ls”。 故障 处理 修复 支持远程
2023-11-04

SQLServer 错误 1793 由于没有为 FILESTREAM 数据指定分区方案,因此无法删除索引“%.*ls”。 故障 处理 修复 支持远程

详细信息 Attribute 值 产品名称 SQL Server 事件 ID 1793 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 ...
SQLServer 错误 1793 由于没有为 FILESTREAM 数据指定分区方案,因此无法删除索引“%.*ls”。 故障 处理 修复 支持远程
2023-11-05

SQLServer 错误 2519 由于无法初始化内部的表达式计算器,从而无法检查对象 ID O_ID(对象 “O_NAME”)的计算列和用户定义类型。 故障 处理 修复 支持

详细信息 Attribute 值 产品名称 SQL Server 事件 ID 2519 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 DBCC_NO_EXPRESSION_EVALUATOR ...
SQLServer 错误 2519 由于无法初始化内部的表达式计算器,从而无法检查对象 ID O_ID(对象 “O_NAME”)的计算列和用户定义类型。 故障 处理 修复 支持
2023-11-05

SQLServer 错误 1418 服务器网络地址 “%.*ls” 无法访问或不存在。 请检查网络地址名称,并检查本地和远程端点的端口是否正常运行。 故障 处理 修复 支持远程

详细信息 Attribute 值 产品名称 SQL Server 事件 ID 1418 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 DBM_PARTNERNOTFOUND 消息正文 ...
SQLServer 错误 1418 服务器网络地址 “%.*ls” 无法访问或不存在。 请检查网络地址名称,并检查本地和远程端点的端口是否正常运行。 故障 处理 修复 支持远程
2023-11-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录