データ型がbigintのSQLサーバーデータベーステーブルに列があります。次に、この列を HH:MM:SS 形式に変換する必要があります。このために、このコマンドを使用します
SELECT cast(CONVERT(VARCHAR,DATEADD(MS,SUM(mFld),0),8) as Time) FROM tblm
しかし、このコマンドは正しい期間を表示しません。適切な期間のために、私はこのコマンドを使用します
SELECT rtrim(LTRIM(cast((mFld/(60*60)) as char)))+':' +rtrim(LTRIM(cast((mFld%(60*60))/(60)as char)))+':'+rtrim(LTRIM(cast(((mFld%(60*60))%(60)) as char))) FROM tblm
このコマンドは正しい結果を示しますが、結果のデータ型は varchar です。この列を同じ結果の時間列に変換するにはどうすればよいですか。
例
DECLARE @minites bigint;
SET @minites = 5200020;
SELECT rtrim(LTRIM(cast((@minites/(60*60)) as char)))+':' +rtrim(LTRIM(cast((@minites%(60*60))/(60)as char)))+':'+rtrim(LTRIM(cast(((@minites%(60*60))%(60)) as char)))
SELECT cast(CONVERT(VARCHAR,DATEADD(MS,SUM(@minites),0),8) as Time)