SQL Server解惑——对象命名的唯一性小结
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQL Server解惑——对象命名的唯一性小结,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5746字,纯文字阅读大概需要9分钟。
内容图文
![SQL Server解惑——对象命名的唯一性小结](/upload/InfoBanner/zyjiaocheng/877/6290f74ef9a44d629a86b714419418c6.jpg)
关于SQL Server数据库中的对象命名的唯一性问题。例如表、索引、约束等数据库对象,有时候DBA在做数据库维护时,经常要创建对象或重命名对象,此时就会遇到一个问题,对象命名的唯一性问题。虽然是一个小小的问题,估计不少人搞不清,在看文章前,你可以先回答几个问题
1: 表名在数据库是不是唯一? 不同的Schema下,是否可以存在同名的表?
2: 索引名在数据库是不是唯一? 不同的Schema下,是否可以存在同名的表?
3: 其它数据库对象呢? 例如约束、触发器。
那么我们接下来看看实验例子吧,如下所示,AdventureWorks2014数据库中存在命名为“Production.Product”的表
USE AdventureWorks2014;
GO
SELECT * FROM sys.objects WHERE OBJECT_ID =OBJECT_ID('Production.Product')
此时创建同名的表,就与遇到“There is already an object named 'Product' in the database.”这个错误。如下所示:
CREATE TABLE Production.Product
(
name NVARCHAR(32)
)
另外,如果我将这个表对象创建在默认的Scheme(dbo)下面,那么这个是没有什么问题的。如下所示:
CREATE TABLE dbo.Product
(
name NVARCHAR(32)
)
结论总结:表名在数据库是唯一,在同一个Schema下,不允许存在相同的表名,但是不同的Schema下,是可以存在同名的表。这个很好理解,现实生活中很多这样的例子,例如,大学寝室, 11栋宿舍楼有201命名的寝室, 13栋宿舍楼也有201命名的寝室。
下面我们生成'Production.Product'的脚本,然后修改一下表名为Product_2020,执行脚本时就会遇到约束已经存在的错误提示(注意,不会一次性显示所有约束已经存在的错误提示)。
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [Production].[Product_2020](
[ProductID] [int] IDENTITY(1,1) NOT NULL,
[Name] [dbo].[Name] NOT NULL,
[ProductNumber] [nvarchar](25) NOT NULL,
[MakeFlag] [dbo].[Flag] NOT NULL CONSTRAINT [DF_Product_MakeFlag] DEFAULT ((1)),
[FinishedGoodsFlag] [dbo].[Flag] NOT NULL CONSTRAINT [DF_Product_FinishedGoodsFlag] DEFAULT ((1)),
[Color] [nvarchar](15) NULL,
[SafetyStockLevel] [smallint] NOT NULL,
[ReorderPoint] [smallint] NOT NULL,
[StandardCost] [money] NOT NULL,
[ListPrice] [money] NOT NULL,
[Size] [nvarchar](5) NULL,
[SizeUnitMeasureCode] [nchar](3) NULL,
[WeightUnitMeasureCode] [nchar](3) NULL,
[Weight] [decimal](8, 2) NULL,
[DaysToManufacture] [int] NOT NULL,
[ProductLine] [nchar](2) NULL,
[Class] [nchar](2) NULL,
[Style] [nchar](2) NULL,
[ProductSubcategoryID] [int] NULL,
[ProductModelID] [int] NULL,
[SellStartDate] [datetime] NOT NULL,
[SellEndDate] [datetime] NULL,
[DiscontinuedDate] [datetime] NULL,
[rowguid] [uniqueidentifier] ROWGUIDCOL NOT NULL CONSTRAINT [DF_Product_rowguid] DEFAULT (newid()),
[ModifiedDate] [datetime] NOT NULL CONSTRAINT [DF_Product_ModifiedDate] DEFAULT (getdate()),
CONSTRAINT [PK_Product_ProductID] PRIMARY KEY CLUSTERED
(
[ProductID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
Msg 2714, Level 16, State 5, Line 11
There is already an object named 'PK_Product_ProductID' in the database.
Msg 1750, Level 16, State 0, Line 11
Could not create constraint or index. See previous errors.
如上所示,约束也是唯一的,它跟表名一样。而且也是跟Schema有关系,如下所示,下面SQL是OK的。
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Product_2020](
[ProductID] [int] IDENTITY(1,1) NOT NULL,
[Name] [dbo].[Name] NOT NULL,
[ProductNumber] [nvarchar](25) NOT NULL,
[MakeFlag] [dbo].[Flag] NOT NULL CONSTRAINT [DF_Product_MakeFlag] DEFAULT ((1)),
[FinishedGoodsFlag] [dbo].[Flag] NOT NULL CONSTRAINT [DF_Product_FinishedGoodsFlag] DEFAULT ((1)),
[Color] [nvarchar](15) NULL,
[SafetyStockLevel] [smallint] NOT NULL,
[ReorderPoint] [smallint] NOT NULL,
[StandardCost] [money] NOT NULL,
[ListPrice] [money] NOT NULL,
[Size] [nvarchar](5) NULL,
[SizeUnitMeasureCode] [nchar](3) NULL,
[WeightUnitMeasureCode] [nchar](3) NULL,
[Weight] [decimal](8, 2) NULL,
[DaysToManufacture] [int] NOT NULL,
[ProductLine] [nchar](2) NULL,
[Class] [nchar](2) NULL,
[Style] [nchar](2) NULL,
[ProductSubcategoryID] [int] NULL,
[ProductModelID] [int] NULL,
[SellStartDate] [datetime] NOT NULL,
[SellEndDate] [datetime] NULL,
[DiscontinuedDate] [datetime] NULL,
[rowguid] [uniqueidentifier] ROWGUIDCOL NOT NULL CONSTRAINT [DF_Product_rowguid] DEFAULT (newid()),
[ModifiedDate] [datetime] NOT NULL CONSTRAINT [DF_Product_ModifiedDate] DEFAULT (getdate()),
CONSTRAINT [PK_Product_ProductID] PRIMARY KEY CLUSTERED
(
[ProductID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
结论:对于任何约束(主键约束、外键约束、默认约束等),在数据库中同一个Schema下是唯一的,不允许存在相同的约束名称,但是不同的Schema下,是可以存在同名的约束。
索引呢,你简单测试一下,就会有所发现情况有点不同。
USE [AdventureWorks2014]
GO
CREATE UNIQUE NONCLUSTERED INDEX [AK_Product_rowguid] ON [Production].[Product_2020]
(
[rowguid] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
GO
为什么索引对象的唯一性是跟前面表对象有所不同呢,这个说实话,实在没有看到详细介绍,只能怀疑是跟SQL Server官方的设定、限制有关系。
SQL Server中可以存在同名的索引吗? 如果是同一个表呢?
答案:不同的表,可以存在同名的索引,但是同一个表,不能存在同名的索引。
对于触发器而言,它跟表名、约束一样的规则。 这里限于篇幅,就不展开了,有兴趣的自行测试一下。
下面将前面的知识用表格总结一下:
|
相同Schema下 |
不同Schema下 |
Table |
不能出现同名对象 |
可以出现同名对象 |
Constraint |
不能出现同名对象 |
可以出现同名对象 |
Index |
可以出现同名对象,但是同一个表,不能存在同名的索引 |
可以出现同名对象 |
Trigger |
不能出现同名对象 |
可以出现同名对象 |
内容总结
以上是互联网集市为您收集整理的SQL Server解惑——对象命名的唯一性小结全部内容,希望文章能够帮你解决SQL Server解惑——对象命名的唯一性小结所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。