線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3161
推到 Plurk!
推到 Facebook!

MS SQL如何將字串"下午 04:32:06"更改成"1632"

尚未結案
cindyliu
一般會員


發表:16
回覆:18
積分:6
註冊:2008-09-17

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-10-30 18:32:19 IP:59.120.xxx.xxx 訂閱
請問該怎麼將字串"下午 04:32:06"更改成"1632" (24小時制的時分)

欄位FLAG2的型態是varchar(25)
UPDATE TABLE1
SET FLAG2 = ......
WHERE LEN(FLAG2) > 4
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-10-30 18:42:00 IP:60.248.xxx.xxx 未訂閱
您好

試看看這樣是不是您要的
select left(dt,2) substring(dt,4,2)
from
(select convert(varchar(10),getdate(),108) dt) t

===================引 用 cindyliu 文 章===================
請問該怎麼將字串"下午 04:32:06"更改成"1632" (24小時制的時分)
cindyliu
一般會員


發表:16
回覆:18
積分:6
註冊:2008-09-17

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-10-31 00:26:34 IP:118.166.xxx.xxx 訂閱
您好...
您這個語法看起來是把真正是日期型態的資料轉換成文字之後再截字串..
可是我的FLAG2這個欄位本身就是文字型態了,只是他的值看起來像日期...
所以不太是我要的樣子耶... ^^"

===================引 用 pedro 文 章===================
您好

試看看這樣是不是您要的
select left(dt,2) substring(dt,4,2)
from
(select convert(varchar(10),getdate(),108) dt) t

===================引 用 cindyliu 文 章===================
請問該怎麼將字串"下午 04:32:06"更改成"1632" (24小時制的時分)
eaglewolf
資深會員


發表:4
回覆:268
積分:429
註冊:2006-07-06

發送簡訊給我
#4 引用回覆 回覆 發表時間:2009-10-31 17:48:41 IP:211.75.xxx.xxx 訂閱
建個cursor 
或 function
來處理吧

create function dbo.TEST (@Time varchar(25)) Returns varchar(25)
AS
begin
-- 在這處理
Return @Time
end
GO
Update ABC Set Flag2=dbo.TEST(Flag2)
GO
Drop Function dbo.TEST
GO

===================引 用 cindyliu 文 章===================
您好...
您這個語法看起來是把真正是日期型態的資料轉換成文字之後再截字串..
可是我的FLAG2這個欄位本身就是文字型態了,只是他的值看起來像日期...
所以不太是我要的樣子耶... ^^"

===================引 用 pedro 文 章===================
您好

試看看這樣是不是您要的
select left(dt,2) substring(dt,4,2)
from
(select convert(varchar(10),getdate(),108) dt) t

===================引 用 cindyliu 文 章===================

請問該怎麼將字串"下午 04:32:06"更改成"1632" (24小時制的時分)
------
先查HELP
再查GOOGLE
最後才發問

沒人有義務替你解答問題
在標題或文章中標明很急
並不會增加網友回答速度

Developing Tool:
1.Delphi 6
2.Visual Studio 2005
3.Visual Studio 2008
DBMS:
MS-SQL
編輯記錄
eaglewolf 重新編輯於 2009-10-31 17:52:03, 註解 增加function ‧
st33chen
尊榮會員


發表:15
回覆:591
積分:1201
註冊:2005-09-30

發送簡訊給我
#5 引用回覆 回覆 發表時間:2009-11-02 15:16:19 IP:114.32.xxx.xxx 未訂閱
您好,

我認為解法有二:
1. datetime 型法
update table1 set flag2 =把 substr(flag2,6,2) 轉成數字 12 再轉成文字 || substr(flag2,9,2)
end
where ...
參考一下

------
IS IT WHAT IT IS
我是 李慕白 請倒著唸.
又想把老話拿出來說, 請用台語發音 : 專家專家全是ROBOT CAR (滷肉腳啦);
都已接手這麼久了, 績效還是那麼爛, 講話還那麼大聲.
cindyliu
一般會員


發表:16
回覆:18
積分:6
註冊:2008-09-17

發送簡訊給我
#6 引用回覆 回覆 發表時間:2009-11-03 21:37:49 IP:118.166.xxx.xxx 訂閱
st33chen~您的方法一看就懂...謝謝您~

===================引 用 st33chen 文 章===================
您好,

我認為解法有二:
1. datetime 型法
??? update table1 set flag2 =把 substr(flag2,6,2) 轉成數字 12 再轉成文字 || substr(flag2,9,2)
? end
? where ...
參考一下

暗黑破壞神
版主


發表:9
回覆:2301
積分:1627
註冊:2004-10-04

發送簡訊給我
#7 引用回覆 回覆 發表時間:2009-11-03 22:51:05 IP:114.46.xxx.xxx 未訂閱
如果我做的話. 我會先看看是不是可以改用24小時制的輸出.
然去看看有沒有 month(), hour()....這一類的函數.
把結果加出來.

===================引 用 cindyliu 文 章===================
請問該怎麼將字串"下午 04:32:06"更改成"1632" (24小時制的時分)

欄位FLAG2的型態是varchar(25)
UPDATE TABLE1
SET FLAG2 = ......
WHERE LEN(FLAG2) > 4
cxh17895
初階會員


發表:13
回覆:37
積分:25
註冊:2003-03-19

發送簡訊給我
#8 引用回覆 回覆 發表時間:2009-11-23 15:03:46 IP:220.134.xxx.xxx 訂閱

[code sql]
select replace(replace(replace(convert(varchar(20),getdate(),20),'-',''),':',''),' ','') As AdateTime
[/code]

試試看這樣,接下來是 SUBSTRING 用法..
出來的內容就是 YYYYMMDDHHMMSS / 20091123145541
系統時間:2024-04-27 10:52:20
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!