SqlServer Text類型欄位超過8000文書處理

來源:互聯網
上載者:User
SqlServer的T-Sql
如下:

表結構:
欄位名         id      title      content
類型            int      char(200)   text
Insert Into News (title,content) Values (@title,@content)

實際上這樣插入是不能超過8000位元組的(content欄位)。SqlServer在這方面做了限制。

可以這樣插入

CREATE PROCEDURE NewsInsert   @title char(200),@content text   AS

Insert Into News (title,content) Values (@title,'')

DECLARE @ptrval binary(16)
SELECT @ptrval = TEXTPTR(content) 
FROM News 
WHERE id = @@identity
writeTEXT News .content @ptrval  @content

GO

用到了writeTEXT函數。
注意:插入的時候Insert Into News (title,content) Values (@title,'')一定要有content值對應空,不能讓content是null狀態.否則下面的無法找到地址。

更新的時候:CREATE PROCEDURE NewsInsert   @title char(200),@content text,@id int   AS

Update News Set title = @title,content='' Where id = @id --注意content=''雖然不起作用,但是最好寫上,避免content有null的情況

DECLARE @ptrval binary(16)
SELECT @ptrval = TEXTPTR(content) 
FROM News 
WHERE id = @id
writeTEXT News .content @ptrval  @content

GO


讀取和刪除的時候一切正常,就不多敘述了。
以上用法可以插入資料庫類型Text對應的理論實際長度以內。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.