黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

存儲過程中調用C#自定義封裝的DLL

系統(tǒng) 2577 0
項目中遇到一個轉換FileTime的問題.時間是在C#中用DateTime.ToFileTime寫入數(shù)據(jù)庫中,這在存儲過程中判斷年和季度成了問題,怎么樣才能把時間轉換為正常的時間格式呢?Sql server中又沒有FromFileTime對應的方法?其實很簡單用C#寫一個轉換時間的Dll然后在存儲過程中調用就可以了.
轉換時間的類如下:
[Guid("729ba6af-3eff-4b75-b43b-d951a190dbe6")]
public class FileTimeConvert
{
?? public FileTimeConvert()
?? {
?? }

?? public string ConvertTime(long fileTime)
?? {
??? string retVal = string.Empty;
??? if (fileTime > 0)
??? {
???? DateTime dt = DateTime.FromFileTime(fileTime);
???? retVal = dt.ToString();???
??? }
??? return retVal;
?? }?
}
注意這個Guid我們在存儲過程中引用要用到這個Guid.

為方便可能在多處需要調用,我們專門寫一個存儲過程
如下:

CREATE PROCEDURE spu_ConvertFileTimeToNormal
@ticks BIGINT,
@returnval varchar(40) output
AS

DECLARE @src varchar(255)
DECLARE @desc varchar(255)


DECLARE @object int
DECLARE @hr int
EXEC @hr = sp_OACreate '{729ba6af-3eff-4b75-b43b-d951a190dbe6}',@object OUT

IF @hr = 0 --如果創(chuàng)建對象成功
BEGIN
?? EXEC @hr = sp_OAMethod @object,'ConvertTime',@returnval OUT,@ticks
???? print @returnval
???? print @hr
?? if(@hr <> 0)
??? BEGIN
????? EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT
???? SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc
??? END
??
?? END

ELSE
BEGIN
?? --print @hr
?? print 'Create Object ConvertTime failed'

???? EXEC sp_OAGetErrorInfo @object, @src OUT, @desc OUT
???? SELECT hr=convert(varbinary(4),@hr), Source=@src, Description=@desc
???? RETURN
END

EXEC @hr = sp_OADestroy @object

IF @hr <> 0
BEGIN
??? EXEC sp_OAGetErrorInfo @object
??? RETURN
END

GO

這個時候我們還差最后一步注冊DLL了
在.net 命令行下輸入 regasm -codebase path

好了,現(xiàn)在我們就可以在其他存儲過程中調用這個存儲過程返回正常的時間了.
給個小例子:
EXEC spu_ConvertFileTimeToNormal @CreateTime,@NormalTime OUT???
@CreateTime:FileTime格式
@NormalTime :正常的時間格式字符串(spu_ConvertFileTimeToNormal 存儲過程返回值)

這個簡單的小例子說明了我們怎么樣在存儲過程中調用DLL
是不是你解決問題又多了一個選擇了呢?

轉自: http://www.cnblogs.com/dcba1112/archive/2011/05/12/2044849.html

存儲過程中調用C#自定義封裝的DLL


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論