数据库一张表里面有个字段是timestamp类型的,
插入一条数据到这张表时,timestamp类型的字段的值好像变成乱码一样~~
这是怎么回事~
插入一条数据到这张表时,timestamp类型的字段的值好像变成乱码一样~~
这是怎么回事~
解决方案 »
- 急救!!!!!!!!!!!!!
- SQLServer中有没有类似Oracal里面merge into 这样的语句,以实现“数据已经登录,则update,数据没有登陆,则insert”这样的功能?在线等
- 根据2列数据SQL可不可以像EXCEL一样通过图表生存相应的趋势公式呢
- 如何生成一个跟系统一样的STATISTICS名称?
- SQL 问题,dawugui ,来看看
- SQL Server2005 安装
- 超简单问题,如何卸载sql 7.0?
- 一个表与另一个表的联接是怎么回事??
- 关于SQL-Server超时的问题!
- 请问什么是在线事务处理(OLAP)??它有什么好处??
- 怎样发现表被修改过
- 这个语句怎么写?
lz看见的是这样的?
0x00000000000007D0
但是好像应该是<Binary>这样吧?
不是么?
可为空的 timestamp 列在语义上等同于 varbinary(8) 列参考!
看看吧!
公开数据库中自动生成的唯一二进制数字的数据类型。timestamp 通常用作给表行加版本戳的机制。 存储大小为 8 个字节。 timestamp 数据类型只是递增的数字,不保留日期或时间。 若要记录日期或时间,请使用 datetime 数据类型。备注
每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加。 该计数器是数据库时间戳。 这可以跟踪数据库内的相对时间,而不是时钟相关联的实际时间。 一个表只能有一个 timestamp 列。 每次修改或插入包含 timestamp 列的行时,就会在 timestamp 列中插入增量数据库时间戳值。 这一属性使 timestamp 列不适合作为键使用,尤其是不能作为主键使用。 对行的任何更新都会更改 timestamp 值,从而更改键值。 如果该列属于主键,那么旧的键值将无效,进而引用该旧值的外键也将不再有效。 如果该表在动态游标中引用,则所有更新均会更改游标中行的位置。 如果该列属于索引键,则对数据行的所有更新还将导致索引更新。使用某一行中的 timestamp 列可以很容易地确定该行中的任何值自上次读取以后是否发生了更改。 如果对行进行了更改,就会更新该时间戳值。 如果没有对行进行更改,则该时间戳值将与以前读取该行时的时间戳值一致。 若要返回数据库的当前时间戳值,请使用 @@DBTS。Transact-SQL timestamp 数据类型不同于在 SQL-2003 标准中定义的 timestamp 数据类型。 SQL-2003 timestamp 数据类型等同于 Transact-SQL datetime 数据类型。rowversion 的数据类型为 timestamp 数据类型的同义词,并具有数据类型同义词的行为。 在 DDL 语句,请尽量使用 rowversion 而不是 timestamp。 有关详细信息,请参阅 数据类型同义词 (Transact-SQL)。在 CREATE TABLE 或 ALTER TABLE 语句中,不必为 timestamp 数据类型指定列名,例如: 复制代码
CREATE TABLE ExampleTable (PriKey int PRIMARY KEY, timestamp);
如果不指定列名,则 Microsoft SQL Server 2005 数据库引擎将生成 timestamp 列名;但 rowversion 同义词不具有这样的行为。 在使用 rowversion 时,必须指定列名。注意:
在使用其中的 SELECT 列表中具有 timestamp 列的 SELECT INTO 语句时,可能会生成重复的时间戳值。 建议不要以这种方式使用 timestamp。
不可为空的 timestamp 列在语义上等同于 binary(8) 列。 可为空的 timestamp 列在语义上等同于 varbinary(8) 列。