SQL Server 2008 某些新语法
一,如何创建排序表1.T-SQL创建一个排序表。
CREATE TABLE OrderTable(
IDENTITY(1,1) NOT NULL,
NOT NULL,
(18, 0) NOT NULL
)
2.T-SQL插入数据到排序表。
Insert into OrderTable (CustomerId, OrderTotal)
Values (1,90),
(2,180),
(6,540)
3.查看结果,如果是在MSSQL2005中插入数据,会报 ',' 附近有语法错误。
二,新语句之MERGE,请参考:http://tech.it168.com/db/2007-07-24/200707242111781.shtml
据IT168技术文档上是说当要对2张表进行信息同步时(合并2张表),有三步操作要进行。首先要处理任何需要插入目标数据表的新行。其次是处理需要更新的已存在的行。最后要删除不再使用的旧行。 一个模板如下:
CREATE TABLE .(
IDENTITY(1,1) NOT NULL,
(18, 0) NULL,
(50) NULL
) ON
GO
SET ANSI_PADDING OFF
GO
ALTER TABLE . ADDDEFAULT ((0)) FOR
GO
ALTER TABLE . ADDDEFAULT ('') FOR
GO
现在我们使用MERGE同步数据:
Merge CustomerTable
Using ( Select CustomerId, OrderTotal From OrderTable ) As OrderSrc (CustId, Amount)
On CustomerTable.CustomerId = OrderSrc.CustId
When MATCHED AND OrderSrc.CustId = 0 THEN
DELETE
When Matched Then
Update Set CustomerTotal = CustomerTotal + OrderSrc.Amount
When Not Matched Then
Insert (CustomerName,CustomerTotal) values (GetDate(), OrderSrc.Amount);
我也没理解,,还是说说目前对次语句的理解:
目标表(需要作用的表)是CustomerTable,源表(参照表)是OrderTable
1.When Matched Then表示 当2张表有一些共同点,就是说CustomerTable.CustomerId = OrderTable.CustomerId 的时候,OrderTable。CustomerTotal 中的值是 更新到CustomerTable。CustomerTotal 。 其实IT168 也提过,,MERGE就是针对join的。
2.When Not Matched Then表示 当 OrderTable 中的记录在 CustomerTable 中没有,,就添加新行。
3.When MATCHED AND OrderSrc.CustId = 0 THEN 其实应该是 When Source Not Matched Then, 我不知道为什么 When Source Not Matched Then 会报错,,因此改成了
When MATCHED AND OrderSrc.CustId = 0 THEN, 这个逻辑其实因该是要表示当源表,,也就是OrderTable中一条数据都没有的话,就DELETE CustomerTable….,我这里没写出来这个逻辑。
MERGE虽然强大,但会在目标表中产生无关的数据…..
三,内置初始化变量
以前的是:
DECLARE @i int
SET @i = 10
现在是:
DECLARE @i int = 10
四,C#数学语法
现在是:
--DECLARE @i int
--SET @i = 10
SET @i += 10
五,微软新引进的 表值参数 Table-Value-Parameters (TVP)
我看到微软ADO的博客写了一个例子:
Create Type Songs_TableType as Table
(Title nvarchar(120) not null,
TrackNumber int)
I can now use this type in a stored procedure to pass a table as a parameter. The following T-Sql shows how to define a stored procedure that takes this type as a parameter. Note that I have skipped error handling for brevity.
create procedure AddSongs(
@ArtistName nvarchar(120),
@AlbumName nvarchar(120),
@Songs Songs_TableType READONLY)
as
begin
-- Add the Artist
Declare @ArtistID int
insert into Artists values (@ArtistName)
select @ArtistID = SCOPE_IDENTITY()
-- Add the Album
Declare @AlbumID int
insert into Albums values (@AlbumName, @ArtistID)
select @AlbumID = SCOPE_IDENTITY()
-- Insert songs
insert into Songs
select title, trackNumber, @AlbumID, @ArtistID
from @Songs
end
但是看得不是很明白,下面是我的简写:
CREATE TYPE MyTableType AS TABLE (CustomerId int, OrderTotal int)
DECLARE @myTableTypeMyTableTypeINSERT @myTableType SELECT 6, 7
Insert into OrderTableSelect CustomerId, OrderTotal from @myTableType
完了,另外,有兴趣的可以看看MSDN的网站http://msdn.microsoft.com/zh-cn/library/ms144275.aspx
共享此文 :
页:
[1]