- 相關(guān)推薦
2017微軟認(rèn)證考試備考復(fù)習(xí)題及答案
第1題
你有一個(gè)名為John的用戶。他對(duì)Sales架構(gòu)有SELECT訪問權(quán)。 你需要從Sales.SalesOrder表消除John的SELECT訪問權(quán), 但又不能影響他的其他權(quán)限。應(yīng)使用哪一條Transact-SQL語句? A. DROP USER John;
B. DENY SELECT ON Sales.SalesOrder TO John;
C. GRANT DELETE ON Sales.SalesOrder TO John;
D. REVOKE SELECT ON Sales.SalesOrder FROM John;
答案:B
第2題
你的數(shù)據(jù)庫(kù)有5GB,并包含名為SalesHistory的表。表中頻繁插入和更新銷售信息。你發(fā)現(xiàn)發(fā)生了過度頁(yè)拆分。你需 要確保減少SalesHistory表的頁(yè)拆分。應(yīng)使用哪個(gè)代碼片段?
A. ALTER DATABASE Sales MODIFY FILE (NAME = Salesdat3, SIZE = 10GB);
B. ALTER INDEX ALL ON Sales.SalesHistory REBUILD WITH (FILLFACTOR = 60);
C. EXEC sys.sp_configure ’fill factor (%)’, ’60’;
D. UPDATE STATISTICS Sales.SalesHistory(Products) WITH FULLSCAN, NORECOMPUTE;
答案:B
第3題
你有一個(gè)名為dbo.Customers的表。該表是使用下面的Transact-SQL語句創(chuàng)建的: CREATE TABLE dbo.Customers (CustomerID int IDENTITY(1,1) PRIMARY KEY CLUSTERED,AccountNumber nvarchar(25) NOT NULL,FirstName nvarchar(50) NOT NULL,LastName nvarchar(50) NOT NULL,AddressLine1 nvarchar(255) NOT NULL,AddressLine2 nvarchar(255) NOT NULL,City nvarchar(50) NOT NULL,StateProvince nvarchar(50) NOT NULL,Country nvarchar(50) NOT NULL,PostalCode nvarchar(50) NOT NULL,CreateDate datetime NOT NULL DEFAULT(GETDATE()),ModifiedDate datetime NOT NULL DEFAULT(GETDATE())) 你創(chuàng)建了一個(gè)存儲(chǔ)過程,其中包含dbo.Customers表的AccountNumber、Country和StateProvince列。該存儲(chǔ)過程接受一 個(gè)參數(shù)來根據(jù)AccountNumber列篩選輸出。你需要優(yōu)化該存儲(chǔ)過程的性能。你不得更改現(xiàn)有表結(jié)構(gòu)。應(yīng)使用哪一條 Transact-SQL語句?
A. CREATE STATISTICS ST_Customer_AccountNumber ON dbo.Customer (AccountNumber) WITH FULLSCAN;
B. CREATE CLUSTERED INDEX IX_Customer_AccountNumber ON dbo.Customer (AccountNumber);
C. CREATE NONCLUSTERED INDEX IX_Customer_AccountNumber ON dbo.Customer (AccountNumber) WHERE AccountNumber = ’’;
D. CREATE NONCLUSTERED INDEX IX_Customer_AccountNumber ON dbo.Customer (AccountNumber) INCLUDE (Country, StateProvince);
答案:D
第4題
你要?jiǎng)?chuàng)建一個(gè)表來存儲(chǔ)客戶的GPS位置。你需要確保該表允許你找出指定銷售地區(qū)的客戶,并計(jì)算客戶與最近店鋪 之間的距離。應(yīng)使用哪種數(shù)據(jù)類型?
A. geometry
B. geography
C. nvarchar(max)
D. varbinary(max) FILESTREAM
答案:B
第5題
你計(jì)劃將名為SmallKey的新列添加到Sales.Product表,該列將在唯一約束中使用。你需要確保在添加新列時(shí),下面的 信息適用: ’a1’和’A1’被視作不同的值 ORDER BY子句中’a’和’A’排在’b’和’B’之前 你需要選擇符合新列的要求的排序規(guī)則。你選擇哪種排序規(guī)則?
A. Latin1_General_BIN
B. SQL_Latin1_General_CP1_CI_AI
C. SQL_Latin1_General_CP1_CI_AS
D. SQL_Latin1_General_CP1_CS_AS
答案:D
第6題
你有多個(gè)表, 它們表示同類實(shí)體的各種屬性。 屬性值的類型有text、 geometry、 varchar(max)以及指定為 “bit NOT NULL” 數(shù)據(jù)類型的用戶類型。你計(jì)劃將多個(gè)表的數(shù)據(jù)整合為一個(gè)表。該表將利用SPARSE選項(xiàng)來使用半結(jié)構(gòu)化存儲(chǔ)。你的 任務(wù)是確定與SPARSE選項(xiàng)兼容的數(shù)據(jù)類型。哪個(gè)數(shù)據(jù)類型與SPARSE選項(xiàng)兼容?
A. text
B. geometry
C. varchar(max)
D. 定義為’bit NOT NULL’的用戶定義類型
答案:C
第7題
你需要?jiǎng)?chuàng)建一個(gè)存儲(chǔ)過程,該過程接受名為@Customers的表值參數(shù)。應(yīng)使用哪個(gè)代碼片段?
A. CREATE PROCEDURE AddCustomers (@Customers varchar(max))
B. CREATE PROCEDURE AddCustomers (@Customers Customer READONLY)
C. CREATE PROCEDURE AddCustomers (@Customers CustomerType OUTPUT)
D. CREATE PROCEDURE ADDCUSTOMERS (@Customers varchar (max)) AS EXTERNAL NAME Customer.Add.NewCustomer
答案:B
第8題
你有一個(gè)用用戶定義函數(shù)實(shí)現(xiàn)的計(jì)算列。該用戶定義函數(shù)返回一個(gè)格式化的帳號(hào)。必須為該列建索引,以提供足夠 的搜索性能。你計(jì)劃對(duì)該計(jì)算列創(chuàng)建索引。你需要確定該用戶定義函數(shù)的ObjectPropertyEX值的有效組合。應(yīng)使用哪 種組合?
A. IsDeterministic = True IsSystemVerified = True UserDataAccess = False SystemDataAccess = False
B. IsDeterministic = True IsSystemVerified = True IsPrecise = True IsTableFunction = True
C. IsDeterministic = False IsSystemVerified = True UserDataAccess = False SystemDataAccess = False
D. IsDeterministic = False IsSystemVerified = True IsPrecise = True SystemDataAccess = False
答案:A
第9題
你要使用Microsoft SQL Server 2008開發(fā)一個(gè)數(shù)據(jù)庫(kù)。該數(shù)據(jù)庫(kù)包含圖中所示的表。你需要實(shí)現(xiàn),如果零件屬于套件, 那么應(yīng)防止刪除這些零件。 如果零件屬于套件, 那么不應(yīng)發(fā)生刪除操作, 并且該行的IsDeleted列不應(yīng)更改為 “True” 。 如果零件不屬于套件,那么可以刪除零件。下面的Transact-SQL語句將在觸發(fā)器中使用: UPDATE p SET IsDeleted = 1 FROM KitPart kpJOIN deleted d ON kp.PartID = d.PartIDJOIN Part p ON kp.PartID = p.PartID; DELETE FROM p FROM Part pJOIN deleted d ON p.PartID = d.PartIDLEFT OUTER JOIN KitPart kp ON p.PartID = kp.PartID WHERE kp.KitID IS NULL; 你需要在觸發(fā)器中實(shí)現(xiàn)該Transact-SQL語句。應(yīng)使用哪個(gè)觸發(fā)器語法?
A. CREATE TRIGGER tr_Part_d ON Part AFTER DELETE AS BEGIN END
B. CREATE TRIGGER tr_Part_d ON Part INSTEAD OF DELETE AS BEGIN END
C. CREATE TRIGGER tr_KitPart_d ON KitPart AFTER DELETE AS BEGIN END
D. CREATE TRIGGER tr_KitPart_d ON KitPart INSTEAD OF DELETE AS BEGIN END
答案:B
第10題
你有名為Products和OrderDetails的表。Products表與OrderDetails表有基于ProductID列的外鍵關(guān)系。你有下面的 Transact-SQL批處理: BEGIN TRY BEGIN TRANSACTION DELETE FROM Products WHERE ProductID = 5;BEGIN TRANSACTION INSERT INTO OrderDetails ( OrderID, ProductID, Quantity )VALUES ( 1234, 5, 12 );COMMIT TRANSACTION COMMIT TRANSACTION END TRY BEGIN CATCH ROLLBACK TRANSACTION PRINT ERROR_MESSAGE();END CATCH 你需要分析執(zhí)行此批處理的結(jié)果。預(yù)期的結(jié)果應(yīng)該是什么?
A. –將從Products表刪除產(chǎn)品。 --訂單詳細(xì)信息將插入OrderDetails表。
B. –將從Products表刪除產(chǎn)品。 --訂單詳細(xì)信息不會(huì)插入OrderDetails表。
C. –不會(huì)從Products表刪除產(chǎn)品。 --訂單詳細(xì)信息將插入OrderDetails表。
D. –不會(huì)從Products表刪除產(chǎn)品。 --訂單詳細(xì)信息不會(huì)插入OrderDetails表。
答案:D
第11題
你有一個(gè)名為Orders的表。你的任務(wù)是修改公司主數(shù)據(jù)庫(kù),以刪除所有無效的訂單行。你正要開發(fā)一個(gè)存儲(chǔ)過程用 來刪除這些行。你編寫了下面的代碼片段來完成此任務(wù)。(包含的行號(hào)僅供參考。) 01 02 03 04 05 06 07 08 09 10 11 12 BEGIN TRY DECLARE @RowCount INT = 1000WHILE @RowCount = 1000BEGIN
DELETE TOP (1000) FROM Orders WHERE Status = ’Inactive’;SET @RowCount = @@ROWCOUNT ... END END TRY BEGIN CATCH PRINT ERROR_MESSAGE() END CATCH
你需要插入一條Transact-SQL語句,該語句在每批行刪除之后立即通知你。應(yīng)在第07行插入哪句Transact-SQL語句?
A. RAISERROR (’Deleted %i rows’, 6, 1, @RowCount)
B. RAISERROR (’Deleted %i rows’, 16, 1, @RowCount)
C. RAISERROR (’Deleted %i rows’, 10, 1, @RowCount) WITH NOWAIT
D. RAISERROR (’Deleted %i rows’, 11, 1, @RowCount) WITH NOWAIT
答案:C
第12題
你在編寫一個(gè)批處理,其中包含修改現(xiàn)有產(chǎn)品的多條UPDATE語句。你將這些更新放在一個(gè)顯式事務(wù)中。你需要在 事務(wù)開始時(shí)設(shè)置一個(gè)選項(xiàng),如果事務(wù)中的任何更新失敗,該選項(xiàng)將回滾所有更改。應(yīng)啟用哪個(gè)選項(xiàng)?
A. ARITHABORT
B. XACT_ABORT
C. IMPLICIT_TRANSACTIONS
D. REMOTE_PROC_TRANSACTIONS
答案:B
第13題
你有名為Sales.SalesOrderHeader和Person.Person的表。你的任務(wù)是編寫一個(gè)查詢來返回OrderDate大于20040101的 SalesOrderID和SalesPersonName。SalesPersonName應(yīng)是將Person.Person表中的FirstName列和LastName列合并而成。 你需要編寫查詢來按字母表順序返回FirstName和LastName合并的數(shù)據(jù)。應(yīng)使用哪一條Transact-SQL語句?
A. SELECT SalesOrderID, FirstName + ’ ’ + LastName as SalesPersonName FROM Sales. SalesOrderHeader H JOIN Person.Person P on BusinessEntityID = H.SalesPersonID WHERE OrderDate > ’20040101’ ORDER BY FirstName ASC, LastName ASC
B. SELECT SalesOrderID, FirstName + ’ ’ + LastName as SalesPersonName FROM Sales. SalesOrderHeader H JOIN Person.Person P on BusinessEntityID = H.SalesPersonID WHERE OrderDate > ’20040101’ ORDER BY FirstName DESC, LastName DESC
C. SELECT SalesOrderID, FirstName +’ ’ + LastName as SalesPersonName FROM Sales. SalesOrderHeader H JOIN Person.Person P on BusinessEntityID = H.SalesPersonID WHERE OrderDate > ’20040101’ ORDER BY SalesPersonName ASC
D. SELECT SalesOrderID, FirstName + ’ ’ + LastName as SalesPersonName FROM Sales. SalesOrderHeader H JOIN Person.Person P on BusinessEntityID = H.SalesPersonID WHERE OrderDate > ’20040101’ ORDER BY SalesPersonName DESC
答案:C
第14題
你有一個(gè)名為Sales.PotentialClients的表。此表有名為EmailAddress的列。你的任務(wù)是開發(fā)一個(gè)報(bào)表,報(bào)表從 Sales.PotentialClients中返回有效的“.com”電子郵件地址。有效電子郵件地址在@符號(hào)前面至少有一個(gè)字符,在@符 號(hào)后面和“.com”之前至少有一個(gè)字符。你需要編寫一條Transact-SQL語句來返回符合該業(yè)務(wù)要求的數(shù)據(jù)。應(yīng)使用 哪一條Transact-SQL語句?
A. select * from Sales.PotentialClients where EmailAddress like ’_%@_%.com’
B. select * from Sales.PotentialClients where EmailAddress like ’%@%.com’
C. select * from Sales.PotentialClients where EmailAddress like ’_%@_.com’
D. select * from Sales.PotentialClients where EmailAddress like ’%@%[.]com’
答案:A
第15題
你有一個(gè)名為Orders的表。OrderID定義為IDENTITY(1,1)。OrderDate默認(rèn)值為1。 你需要編寫查詢將新訂單插入Orders表,該訂單的CustomerID為45,日期是今天,成本為89.00。應(yīng)使用哪條語句?
A. INSERT INTO Orders (CustomerId, OrderDate, Cost) VALUES (45, DEFAULT, 89.00);
B. INSERT INTO Orders (OrderID, CustomerId, OrderDate, Cost) VALUES (1, 45, DEFAULT, 89.00);
C. INSERT INTO Orders (CustomerId, OrderDate, Cost) VALUES (45, CURRENT_TIMESTAMP, 89.00);
D. INSERT INTO Orders (OrderID, CustomerId, OrderDate, Cost) VALUES (1, 45, CURRENT_TIMESTAMP, 89.00);
答案:C