佳礼资讯网

 找回密码
 注册

ADVERTISEMENT

查看: 1227|回复: 7

请问SQL server 2000 里的 datetime field 的问题

[复制链接]
发表于 1-2-2005 10:45 PM | 显示全部楼层 |阅读模式
我已经在我的电脑set 了date的regional setting 去dd/MM/yyyy , 然后我用query
analyzer execute 以下的sql statement:
insert into tblA values('31/12/05')

出现下面的error:
Server: Msg 242, Level 16, State 3, Line 1
The conversion of a char data type to a datetime data type resulted in an
out-of-range datetime value.
The statement has been terminated.

然后我set 了date的regional setting 去MM/dd/yyyy, 也一样是出现同样的error.

是不是sql statement 的date format一定是dd/MM/yyyy, 而不需要理会电脑的regional
settings 呢?

谢谢.
回复

使用道具 举报


ADVERTISEMENT

发表于 1-2-2005 11:42 PM | 显示全部楼层
没用的, 你要自行在 sql syntax 里用 CONVERT.
回复

使用道具 举报

maybird_2 该用户已被删除
发表于 2-2-2005 07:57 AM | 显示全部楼层
看到你另外一则帖的示范,我已明白了。就是我放的日期是什么格式,就放什么代码进去,如dd/mm/yyyy就放103。谢谢。

CONVERT(DATETIME,MyDateValue,103)

Values for the 3rd parameter.
1     mm/dd/yy
2     yy.mm.dd
3     dd/mm/yy
4     dd.mm.yy
5     dd-mm-yy
6     dd mon yy
7     mon dd, yy
10     mm-dd-yy
11     yy/mm/dd
12     yymmdd

Add 100 to a style value to get a four-place year that includes the century (yyyy).

[ Last edited by maybird_2 on 2-2-2005 at 08:04 AM ]
回复

使用道具 举报

 楼主| 发表于 17-3-2005 03:37 PM | 显示全部楼层

  1. .....
  2. dim sSQL as String
  3. dim dsDataSet as DataSet
  4. dim startDate as Date
  5. dim endDate as Date

  6. startDate = StartDateOfMonth(2005, 3) 'return 01 March 2005
  7. endDate = EndDateOfMonth(2005, 4) 'return 31 March 2005

  8. sSQL = "select oid, description from tblA " & _
  9.        "where oDate between convert(datetime, '" & startDate & "', 103) " & _
  10.        "and convert(datetime, '" & endDate & "', 103)"

  11. dsDataSet = SqlRetrieveData(sSQL, "datasetA" ,gSQLConn)
  12. .....
复制代码



  1. Public Function SqlRetrieveData(ByVal sSQL As String, ByVal sTable As String, ByVal sConnectStr As String) As DataSet
  2.     Dim myConnection As New SqlConnection
  3.     Dim myDataAdapter As New SqlDataAdapter
  4.     Dim dsDataSet As New DataSet

  5.     Try
  6.         'Initiate a Sql connection
  7.         myConnection.ConnectionString = sConnectStr
  8.         myConnection.Open()

  9.         'Initiate SqlDataAdapter
  10.         myDataAdapter.SelectCommand = New SqlCommand(sSQL, myConnection)
  11.         myDataAdapter.Fill(dsDataSet, sTable)

  12.     Catch ex As Exception
  13.         MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error)
  14.     End Try

  15.     'Close connection
  16.     myConnection.Close()
  17.     myConnection = Nothing

  18.     Return dsDataSet
  19. End Function



  20. Public Function EndDateOfMonth(ByVal iyear As Integer, ByVal iMonth As Integer) As Date
  21.     Dim dteDate As Date
  22.     dteDate = DateSerial(iyear, iMonth, 0)

  23.     Return dteDate
  24. End Function

  25. Public Function StartDateOfMonth(ByVal iyear As Integer, ByVal iMonth As Integer) As Date
  26.     Dim dteDate As Date
  27.     dteDate = DateSerial(iyear, iMonth, 1)

  28.     Return dteDate
  29. End Function
复制代码

[ Last edited by DRAGONISM on 17-3-2005 at 03:44 PM ]
回复

使用道具 举报

发表于 17-3-2005 03:55 PM | 显示全部楼层
个人通常在Front End,先Format成‘2005-12-15',
这样的格式能确保任何SQL Server Datetime都能接受。
回复

使用道具 举报

 楼主| 发表于 17-3-2005 03:58 PM | 显示全部楼层
小弟有个疑问,以上Part 1的coding在Regional Setting dd/MM/yyyy 的电脑跑没有问题。

可是在Regional Setting MM/dd/yyyy 的电脑跑就出现问题于要执行SQL statement的时候,error是

The conversion of a char data type to a datetime data type resulted in an out-of-range datetime value. The statement has been terminated.

我知道有一个解决方法是:
  1. .....
  2. dim sSQL as String
  3. dim dsDataSet as DataSet
  4. dim startDate as Date
  5. dim endDate as Date

  6. startDate = StartDateOfMonth(2005, 3) 'return 01 March 2005
  7. endDate = EndDateOfMonth(2005, 4) 'return 31 March 2005

  8. sSQL = "select oid, description from tblA " & _
  9.        "where oDate between convert(datetime, '" & Format(startDate, "dd/MM/yyyy") & "', 103) " & _
  10.        "and convert(datetime, '" & Format(endDate, "dd/MM/yyyy") & "', 103)"

  11. dsDataSet = SqlRetrieveData(sSQL, "datasetA" ,gSQLConn)
  12. .....
复制代码

可是我知道应该还有更简单的方法去写这个SQL,希望有网友可以教一教我。谢谢

注:我用VB.NET

[ Last edited by DRAGONISM on 17-3-2005 at 04:03 PM ]
回复

使用道具 举报

Follow Us
发表于 18-3-2005 12:52 AM | 显示全部楼层
用 Microsoft SQL server 吗?
试试这个,希望可以帮到你!

Select   <column_name>
   From  <table_name>
   Where <column_name> = cast('2005-12-31' as datetime);

[ Last edited by cswah_yy on 18-3-2005 at 12:54 AM ]
回复

使用道具 举报

发表于 18-3-2005 06:25 AM | 显示全部楼层
DRAGONISM 于 17-3-2005 03:58 PM  说 :
小弟有个疑问,以上Part 1的coding在Regional Setting dd/MM/yyyy 的电脑跑没有问题。

可是在Regional Setting MM/dd/yyyy 的电脑跑就出现问题于要执行SQL statement的时候,error是

The conversion of a c ...


用vb.net? 那就让.net 去处理....

eg:
myDataAdapter.SelectCommand.Parameters.Add("@DateOfBirth", SqlDbType.DateTime).Value = aDateTimeTypeVariable

*aDateTimeTypeVariable 是 datetime type, 不用自己convert去string type. 所以你没有format的问题
回复

使用道具 举报


ADVERTISEMENT

您需要登录后才可以回帖 登录 | 注册

本版积分规则

 

ADVERTISEMENT



ADVERTISEMENT



ADVERTISEMENT

ADVERTISEMENT


版权所有 © 1996-2023 Cari Internet Sdn Bhd (483575-W)|IPSERVERONE 提供云主机|广告刊登|关于我们|私隐权|免控|投诉|联络|脸书|佳礼资讯网

GMT+8, 29-11-2024 05:36 AM , Processed in 0.113038 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表