sp_addlinkedserver '(null)' is an invalid product name

简介:

使用SSMS 2008客户端工具逆向生成了创建链接服务器的脚本时,在测试环境执行是报如下错误:'(null)' is an invalid product name.

USE [master]
GO
IF EXISTS (SELECT srv.NAME 
           FROM   sys.servers srv 
           WHERE  srv.server_id != 0 
                  AND srv.NAME = N'MES_DB_LINK_TEST') 
  EXEC master.dbo.Sp_dropserver 
    @server=N'MES_DB_LINK_TEST', 
    @droplogins='droplogins' 
 
go 
 
EXEC master.dbo.Sp_addlinkedserver 
  @server = N'MES_DB_LINK_TEST', 
  @provider=N'SQLNCLI', 
  @datasrc=N'192.168.xxx.xxx', 
  @catalog=N'TEST' 
 
EXEC master.dbo.Sp_addlinkedsrvlogin 
  @rmtsrvname=N'MES_DB_LINK_TEST', 
  @useself=N'False', 
  @locallogin=NULL, 
  @rmtuser=N'tuser', 
  @rmtpassword='123456' 
 
go 

消息 15429,级别 16,状态 1,过程 sp_addlinkedserver,第 45 行

'(null)' is an invalid product name.

出现如上错误,是因为这个是SQL Server Management Studio 的一个bug来的。它逆向生成脚本时,生成的脚本少了一些参数,所以你执行脚本时就会报上述错误。这个bug已经在SQL Server Management Studio 2012解决了,你用SSMS 2012逆向生成脚本就会发现会多一个参数@srvproduct

USE [master] 
 
go 
 
IF EXISTS (SELECT srv.NAME 
           FROM   sys.servers srv 
           WHERE  srv.server_id != 0 
                  AND srv.NAME = N'MES_DB_LINK_TEST') 
  EXEC master.dbo.Sp_dropserver 
    @server=N'MES_DB_LINK_TEST', 
    @droplogins='droplogins' 
 
go 
 
EXEC master.dbo.Sp_addlinkedserver 
  @server = N'MES_DB_LINK_TEST', 
  @srvproduct=N'', 
  @provider=N'SQLNCLI', 
  @datasrc=N'192.168.xxx.xxx', 
  @catalog=N'TEST' 
 
EXEC master.dbo.Sp_addlinkedsrvlogin 
  @rmtsrvname=N'MES_DB_LINK_TEST', 
  @useself=N'False', 
  @locallogin=NULL, 
  @rmtuser=N'tuser', 
  @rmtpassword='123456' 
 
go 

  

相关文章
|
7月前
|
机器学习/深度学习 SQL 关系型数据库
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
90 0
|
7月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL NULL 值处理
总结 vue3 的一些知识点:MySQL NULL 值处理
|
7月前
|
SQL 关系型数据库 MySQL
MySQL NULL 值处理
MySQL NULL 值处理
|
7月前
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用合集之从MySQL同步数据到Doris时,历史数据时间字段显示为null,而增量数据部分的时间类型字段正常显示的原因是什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStreamAPI、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
7月前
|
SQL 关系型数据库 MySQL
python在mysql中插入或者更新null空值
这段代码是Python操作MySQL数据库的示例。它执行SQL查询从表`a_kuakao_school`中选取`id`,`university_id`和`grade`,当`university_id`大于0时按升序排列。然后遍历结果,根据`row[4]`的值决定`grade`是否为`NULL`。若不为空,`grade`被格式化为字符串;否则,设为`NULL`。接着构造UPDATE语句更新`university`表中对应`id`的`grade`值,并提交事务。重要的是,字符串`NULL`不应加引号,否则更新会失败。
170 2
|
4月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 IS NULL
【8月更文挑战第12天】
665 0
在 MySQL 中使用 IS NULL
|
4月前
|
SQL 关系型数据库 MySQL
mysql不等于<>取特定值反向条件的时候字段有null值或空值读取不到数据
对于数据库开发的专业人士来说,理解NULL的特性并知道如何正确地在查询中处理它们是非常重要的。以上所介绍的技巧和实例可以帮助你更精准地执行数据库查询,并确保数据的完整性和准确性。在编写代码和设计数据库结构时,牢记这些细节将有助于你避免许多常见的错误,提高数据库应用的质量与性能。
142 0
|
5月前
|
SQL 存储 索引
MySQL设计规约问题之为什么应该把字段定义为NOT NULL并且提供默认值
MySQL设计规约问题之为什么应该把字段定义为NOT NULL并且提供默认值
|
6月前
|
SQL 关系型数据库 MySQL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
469 0