java实训题目:源管理系统。
答辩的时候被老师怼了以下几个的地方:
1.主键改变了
2.没时间戳却说自己的程序里有先后(这就是老师迂腐了,主键自增可以间接反馈出他加入的早晚,即使主键做出了改变但只是做了交换,而不是胡乱的改。所以这并没有影响主键显示某一行加入早晚的功能)
反思:
其实12两点错误负负得正了,确实巧妙的实现了功能。
其实对于还没学过数据库原理的人来讲,只要实现功能就行了。
但老师说是歪门邪道也不无道理,毕竟将来可能还会有人来改或者拓展我的代码对吧,总要符合一定的原则的。
拓展知识:
主键不能更改的原因:
主键用途:
1. 惟一地标识一行。
2. 作为一个可以被外键有效引用的对象。
看了一下网上所有可以搜集到的资料,基本意思就是:如果主键有意义的话,当有需求需要更改这个值的时候(例如拿电话号码当主键,电话号码需要统一变形的话),如果外部链接到了这一行,用的就是主键,那么改的时候整个就很麻烦了。
时间戳:
定义:数据库中自动生成的唯一二进制数字,与时间和日期无关的, 通常用作给表行加版本戳的机制。
存储大小: 8个字节。
每个数据库都有一个计数器,当对数据库中包含 timestamp 列的表执行插入或更新操作时,该计数器值就会增加。
该计数器是数据库时间戳。
这可以跟踪数据库内的相对时间,而不是时钟相关联的实际时间。
一个表只能有一个 timestamp 列。
每次修改或插入包含 timestamp 列的行时,就会在 timestamp 列中插入增量数据库时间戳值。
这一属性使 timestamp 列不适合作为键使用,尤其是不能作为主键使用。
对行的任何更新都会更改 timestamp 值,从而更改键值。
如果该列属于主键,那么旧的键值将无效,进而引用该旧值的外键也将不再有效。
如果该表在动态游标中引用,则所有更新均会更改游标中行的位置。如果该列属于索引键,则对数据行的所有更新还将导致索引更新。
使用某一行中的 timestamp 列可以很容易地确定该行中的任何值自上次读取以后是否发生了更改。如果对行进行了更改,就会更新该时间戳值。如果没有对行进行更改,则该时间戳值将与以前读取该行时的时间戳值一致。若要返回数据库的当前时间戳值,请使用 @@DBTS。
在控制并发时起到作用:
用户A/B同时打开某条记录开始编辑,保存是可以判断时间戳,因为记录每次被更新时,系统都会自动维护时间戳,所以如果保存时发现取出来的时间戳与数据库中的时间戳如果不相等,说明在这个过程中记录被更新过,这样的话可以防止别人的更新被覆盖.