sql2000默认的datetime类型显示格式如图。
部分版本会有差别。
SQL的convert函数可以按需求转换显示格式。
CONVERT(data_type(length),data_to_be_converted,style)
data_type(length) 规定目标数据类型(带有可选的长度)。data_to_be_converted 含有需要转换的值。style 规定日期/时间的输出格式。
以getdate()为例,如图:
把那个字段的数据类型换成字符型 也就是Varchar 或者Nvarchar这种是不会变的或都变成SmallDateTime这种类型
再有取值的时候也要用DateTime类型来取
原来的应该是DateTime类型的自动长度就是那样就算只赋值年月也会自动把时分秒赋上值
datetime和interval是两种与时间有关的数据类型 它们的作用体现在以下几个方面 创建或者更改记录库中的某条记录 当某个时间发生时运行记录 或者计算某个datetime变量建立后所经历过的时间 本文将介绍SQL 标准对上述两种数据类型的描述 SQL数据类型如果你想进一步了解SQL数据类型 请阅读SQL基础 字符串型数据类型 这篇文章的范围覆盖了SQL中的通用数据类型并说明了各种字符串数据类型的用法 SQL基础 数字数据类型详细介绍了数字数据类型 Datetime用于表示时间或者日期的数据类型都属于datetime类型 每一种datetime数据类型都有他自己的用于获取值的长度和它所保存信息的手段 如天 月 分钟 秒 秒的小数等等 实际上 datetime的实现形式随着定义它的标准不同而拥有不同的长度和格式 然而 各个公司定义的类型都内在地符合下述规则 举例来说 时标(timestamp)的某个实现可能没有分隔符 随着细节的规范不同 长度和格式也发生变化 在某些场合以空格做为间隔符 Datetime数据类型包括 DATA TIME和TIMESTAMP 让我们仔细研究这些分类 首先我们看看DATA DATA用法 DATADATA类型允许没有参数 如精度 DATA的字段包括年 月和日 DATA的长度为十个字符 YYYY MM DD (Y表示年 M表示月 D表示日 ) 它只允许与其它DATA类型字段相比较 允许的数字必须符合公历的规范 TIME用法 TIME(精度)该类型包含了小时 分和秒 格式为hh:mm:ss(h表示小时 m表示分 s表示秒) 精度可选择 (……) 时间以世界标准时间(Universal Coordinated Time UTC)为准 即 : : 表示 格林威治的午夜 服务器的时区隐含的 如果不需要秒的小数部分 那么TIME的长度为八个字符 否则就是八位长度在加上精度 hh:mm:ss p 它只能与其它TIME类型数据进行比较 如果没有指定精度 精度默认为 TIME WITH TIME ZONE 用法 TIME (精度) WITH TIME ZONE 这个值要符合TIME数据类型 TIMEZONE部分表示相对UTC的时差 : : +hh:mm 它的范围为 : 到 : 精度表示秒的小数部分 带有TIMEZONE的TIME长度为 个字符加上精度 在加上一个分隔符 只可以与带有TIMEZONE的TIME类型数据进行比较 TIMESTAMP用法 TIMESTAMP(精度)该类型包含有年 月 日 时 分 秒 格式为 YYYY MM DD hh:mm:ss 可以包括秒的小数部分 这由定义的精度决定 它的日期部分符合公历标准 时间部分为UTC格式 默认为当地时区 时标的长度为 个字符 加上精度 在加上精度分隔符 许多系统偏离上述定义的长度 如UNIX风格时标格式为 YYYY MM DD hh:mm:ss p 如果没有定义精度 默认值为 但是许多数据库公司默认为 所以请参考你的开发文档 时标只可以与其它TIMESTAMP类型的值相比较 TIMESTAMP WITH TIME ZONE用法 TIMESTAMP(精度)WITH TIME ZONE 时标部分符合上述TIMESTAWP的规则 精度代表秒的小数部分 时区部分的要求和TIME WITH TIME ZONE一样 即时区符合UTC规范 范围在 : 到 + : 之间 总长度为 个字符 加上精度 加上一个精度分隔符 YYYY MM DD hh:mm:ss p 它只能与其它TIMESTAMP WITH TIME ZONE类型的数据进行比较 IntervalInterval用于表示时间尺度 例如 你可以用 *** 作符(将在下面进行解释)去计算两个日期间天数并加以保存 各个公司在处理interval上有很大的不同——有些公司提供不同的度量单位 如年或者分钟 而有些公司在根本就不支持interval SQL 标准的interval类型只提供一种子类型 INTERVAL INTERVAL 用法 INTERVAL (限定语)有两种类型的interval 一种为 年份-月份 即保存年份和月份(YYYY MM) 一种为 天-时间 (DD HH:MM:SS) 用来保存天数 小时 分钟和秒 限定语——在某些数据库中interval前导精度(lead precision)——根据其值来指示interval采用 年份-月份 还是 天-时间 方式 interval可正可负 当与其它interval类型变量相比较时 结果保持最大精度 如有必要则补零 INTERVAL全部由整数组成 除了含有小数的秒之外 年份-月份 类型的interval变量只能与其它的 年份-月份 的interval变量进行比较 天-时间 类型也与此类似 *** 作符 *** 作结果类型当处理日期时间时 时区保持不变——尽管有些数据库为了比较而将其中的一个时区转换为另一个 存在一些 *** 作关键字 如OVERLAPS和EXTRACT 它们用于 *** 作和比较datetime类型数据 然而 不同的数据库在这些 *** 作关键字用法和支持方式上有着很大的不同 OVERLAPS用于计算时间交叠的跨度 其 *** 作对象可以是两个datetime也可以是一个datetime和一个interval EXTRACT用于提取datetime或者interval类型数据的某个部分 如在DATA类型数据中提取月份 数据类型由于已建立的标准是为了各公司在现有基础上实现实际上的数据类型的 因此在具体限制 参数和数据类型等方面 你还是需要经常参考你的数据库文档 lishixinzhi/Article/program/SQLServer/201311/22163
区别1:
①date类型可用于需要一个日期值而不需要时间部分时;
②datetime类型:可用于需要同时包含日期和时间信息的值。
区别2:
①date:MySQL 以 'YYYY-MM-DD' 格式检索与显示date值;
②datetime:MySQL 以 'YYYY-MM-DD HH:mm:ss'格式检索与显示 DATETIME 类型。
扩展资料:
SQL:
结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。
结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。
1986年10月,美国国家标准协会对SQL进行规范后,以此作为关系式数据库管理系统的标准语言(ANSI X3 135-1986),1987年得到国际标准组织的支持下成为国际标准。
不过各种通行的数据库系统在其实践过程中都对SQL规范作了某些编改和扩充。
所以,实际上不同数据库系统之间的SQL不能完全相互通用。
date:
(1)省略 年/月/日 显示系统日期并提示输入新的日期,不修改则可直接按回车键,要修改则直接输入新日期。
⑵当机器开始启动时,有自动处理文件(AUTOEXECBAT)被执行,则系统不提示输入系统日期。否则,提示输入新日期和时间。
DateTimePicker控件:
C/S设计中的DateTimePicker控件[1],有两种 *** 作模式:
1下拉式日历模式(缺省)—允许用户显示一种能够用来选择日期的下拉式日历。
2时间格式模式—允许用户在日期显示中选择一个字段(例如:月、日、年等等),按下控件右边的上下箭头来设置它的值。
可以自定义控件的下拉式日历的外观。
使用各种颜色属性,例如CalendarBackColor,CalendarForeColor,CalendarTitleBackColor,CalendarTitleForeColor和CalendarTrailingForeColor,允许创建属于您自己的颜色方案。
可以使用键盘或鼠标对控件进行浏览。下拉式日历有两个按钮使您能够滚动月份数据出入视图。
参考资料:
1varchar,0在数据库中作为字符串中的一个字符是不能被隐藏的,而作为int则会被隐藏;
2datetime,专门用于存放时间的数据类型;
3字符串,字符只是一字符串中的一个个体,字符只能表示一个字母或汉字;
4
首先,我们来看下nvarchar和varchar的官方帮助里的说明:
varchar(n)
长度为
n
个字节的可变长度且非
unicode
的字符数据。n
必须是一个介于
1
和
8,000
之间的数值。存储大小为输入数据的字节的实际长度,而不是
n
个字节。所输入的数据字符长度可以为零。varchar
在
sql-92
中的同义词为
char
varying
或
character
varying。
nvarchar(n)
包含
n
个字符的可变长度
unicode
字符数据。n
的值必须介于
1
与
4,000
之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar
在
sql-92
中的同义词为
national
char
varying
和
national
character
varying。
二、该如何选择两种字符呢?
varchar和nvarchar都能存储汉字。区别在于,一个汉字占varchar(2),只占nvarchar(1),而字母只占varchar(1),那么在数据库字段求长度的时候,用varchar你就不一定知道它确切的知道它到底有几个字,如果用nvarchar,那么汉字也是nvarchar(1),字母也是nvarchar(1),那么已经很明显了
同时,varchar的检索快于nvarchar。
至于,具体该选择哪种,看你自己的想法和需求了
5单引号表示单引号中的数据是实际数据,如:int
test=5;
select
'test'与select
test不同,前者会是字符串test,而后者则是5
6'
'表示的是一个空格,表明name1与name2中间有一个空格,而三者组合成一个字符串并且所在的列命名为name
当你需要同时包含日期和时间信息的值时则使用DATETIME类型。MySQL以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'。(“支持”表示尽管先前的值可能工作,但没有保证)。
当你只需要日期值而不需要时间部分时应使用DATE类型。MySQL用'YYYY-MM-DD'格式检索和显示DATE值。支持的范围是'1000-01-01'到 '9999-12-31'。
TIMESTAMP列类型的属性不固定,取决于MySQL版本和服务器运行的SQL模式。这些属性将在本节后面描述。
可以使用任何常见格式指定DATETIME、DATE和TIMESTAMP值:
'YYYY-MM-DD HH:MM:SS'或'YY-MM-DD HH:MM:SS'格式的字符串。允许“不严格”语法:任何标点符都可以用做日期部分或时间部分之间的间割符。例如,'98-12-31 11:30:45'、'981231 11+30+45'、'98/12/31 113045'和'98@12@31 11^30^45'是等价的。
'YYYY-MM-DD'或'YY-MM-DD'格式的字符串。这里也允许使用“不严格的”语法。例如,'98-12-31'、'981231'、'98/12/31'和'98@12@31'是等价的。
'YYYYMMDDHHMMSS'或'YYMMDDHHMMSS'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523091528'和'970523091528'被解释为'1997-05-23 09:15:28',但'971122129015'是不合法的(它有一个没有意义的分钟部分),将变为'0000-00-00 00:00:00'。
'YYYYMMDD'或'YYMMDD'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523'和'970523'被解释为 '1997-05-23',但'971332'是不合法的(它有一个没有意义的月和日部分),将变为'0000-00-00'。
YYYYMMDDHHMMSS或YYMMDDHHMMSS格式的数字,假定数字对于日期类型是有意义的。例如,19830905132800和830905132800被解释为 '1983-09-05 13:28:00'。
YYYYMMDD或YYMMDD格式的数字,假定数字对于日期类型是有意义的。例如,19830905和830905被解释为'1983-09-05'。
函数返回的结果,其值适合DATETIME、DATE或者TIMESTAMP上下文,例如NOW()或CURRENT_DATE。
无效DATETIME、DATE或者TIMESTAMP值被转换为相应类型的“零”值('0000-00-00 00:00:00'、'0000-00-00'或者00000000000000)。
对于包括日期部分间割符的字符串值,如果日和月的值小于10,不需要指定两位数。'1979-6-9'与'1979-06-09'是相同的。同样,对于包括时间部分间割符的字符串值,如果时、分和秒的值小于10,不需要指定两位数。'1979-10-30 1:2:3'与'1979-10-30 01:02:03'相同。
数字值应为6、8、12或者14位长。如果一个数值是8或14位长,则假定为YYYYMMDD或YYYYMMDDHHMMSS格式,前4位数表示年。如果数字 是6或12位长,则假定为YYMMDD或YYMMDDHHMMSS格式,前2位数表示年。其它数字被解释为仿佛用零填充到了最近的长度。
指定为非限定符字符串的值使用给定的长度进行解释。如果字符串为8或14字符长,前4位数表示年。否则,前2位数表示年。从左向右解释字符串内出现的各部分,以发现年、月、日、小时、分和秒值。这说明不应使用少于6字符的字符串。例如,如果你指定'9903',认为它表示1999年3月,MySQL将在你的表内插入一个“零”日期值。这是因为年和月值是99和03,但日部分完全丢失,因此该值不是一个合法的日期。但是,可以明显指定一个零值来代表缺少的月或日部分。例如,可以使用'990300'来插入值'1999-03-00'。
在一定程度上,可以将一个日期类型的值分配给一个不同的日期类型。但是,值可能会更改或丢失一些信息:
如果你为一个DATETIME或TIMESTAMP对象分配一个DATE值,结果值的时间部分被设置为'00:00:00',因为DATE值未包含时间信息。
如果你为一个DATE对象分配一个DATETIME或TIMESTAMP值,结果值的时间部分被删除,因为DATE值未包含时间信息。
记住尽管可以使用相同的格式指定DATETIME、DATE和TIMESTAMP值,不同类型的值的范围却不同。例如,TIMESTAMP值不能早于1970或晚于2037。这说明一个日期,例如'1968-01-01',虽然对于DATETIME或DATE值是有效的,但对于TIMESTAMP值却无效,如果分配给这样一个对象将被转换为0。
当指定日期值时请注意某些缺陷:
指定为字符串的值允许的非严格格式可能会欺骗。例如,值'10:11:12'由于‘:’间割符看上去可能象时间值,但如果用于日期上下文值则被解释为年'2010-11-12'。值'10:45:15'被转换为'0000-00-00'因为'45'不是合法月。
在非严格模式,MySQL服务器只对日期的合法性进行基本检查:年、月和日的范围分别是1000到9999、00到12和00到31。任何包含超出这些范围的部分的日期被转换成'0000-00-00'。请注意仍然允许你保存非法日期,例如'2002-04-31'。要想确保不使用严格模式时日期有效,应检查应用程序。
在严格模式,非法日期不被接受,并且不转换。
包含两位年值的日期会令人模糊,因为世纪不知道。MySQL使用以下规则解释两位年值:
00-69范围的年值转换为2000-2069。
70-99范围的年值转换为1970-1999。
以上就是关于sql 2000数据库中datetime类型的显示格式是什么样的全部的内容,包括:sql 2000数据库中datetime类型的显示格式是什么样的、C# 读取 数据库 datetime 日期数据问题、跟我学SQL:datetime和interval数据类型等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)