select CONVERT(varchar(10), getDate(),120) --不要时间2002-1-1
select convert(char(8),getdate(),112) ----20020101
select convert(char(8),getdate(),108)  ---06:05:05 101 美国 mm/dd/yyyy 
2 102 ANSI yy.mm.dd 
3 103 英国/法国 dd/mm/yy 
4 104 德国 dd.mm.yy 
5 105 意大利 dd-mm-yy 
6 106 - dd mon yy 
7 107 - mon dd, yy 
8 108 - hh:mm:ss 
- 9 或 109 (*)  默认值 + 毫秒 mon dd yyyy hh:mi:ss:mmmAM(或 PM) 
10 110 美国 mm-dd-yy 
11 111 日本 yy/mm/dd 
12 112 ISO yymmdd 
- 13 或 113 (*)  欧洲默认值 + 毫秒 dd mon yyyy hh:mm:ss:mmm(24h) 
14 114 - hh:mi:ss:mmm(24h) 
- 20 或 120 (*)  ODBC 规范 yyyy-mm-dd hh:mm:ss[.fff] 
- 21 或 121 (*)  ODBC 规范(带毫秒) yyyy-mm-dd hh:mm:ss[.fff] 
- 126(***) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格) 
- 130* 科威特 dd mon yyyy hh:mi:ss:mmmAM 
- 131* 科威特 dd/mm/yy hh:mi:ss:mmmAM

解决方案 »

  1.   

    select * from table10 where  CONVERT(varchar(10), dt,120)='2003-10-30'
      

  2.   

    我要查询的年和月是从两个下拉列表框中选择而来的,
    那么怎么实现根据下拉列表框中的年月值来查询呢?
    也就是select * from table10 where  CONVERT(varchar(10), dt,120)='2003-10-30'中
    '2003-10-30'用来什么来代替?
      

  3.   

    select * from table10 where year(dt)=2002 and month(dt)=10
      

  4.   

    select * from table0 where to_char( 日期, 'YYYY-MM' ) = '2003-10'
      

  5.   

    select * from table10 where year(dt)=listbox.Yearvalue and month(dt)=listbox.Monthvalue
    listbox.Monthvalue
    listbox.Yearvalue 
    这两个变量可以用你从下拉列表框中的年月值来替换
      

  6.   

    select * from tablename where year(datefield)=2003select * from tablename where month(datefield)=10
    其中"="是可以替换的呀。。
      

  7.   

    --用convert,例如,查询2003年1月的数据select * from 表 where convert(varchar(6),时间字段,112)='200301'
      

  8.   

    从下拉框中得到年月查询可以用:select * from 表 where year(时间字段)=选择的年份 and month(时间字段)=选择的月份
      

  9.   

    按年查詢
    select * from 表名 where substring(convert(varchar(10),時間字段,111),1,4)=選擇的年
    按月查詢
    select * from 表名 where substring(convert(varchar(10),時間字段,111),1,7)=選擇的月
      

  10.   

    下拉框的话还是 pengdali(大力 V3.0)说的方便。