(5)查询编码历史记录

切换到新的分支进行开发

git checkout -b fifth/history

案例

添加路由

get 'barcode_scanner_four'
get 'barcode_history'

生成历史记录时,ID需要自动生成而不是我们给ID赋值。为了确保ID唯一,我们可以使用一个自动生成ID的gem,我们在Gemfile添加gem 'uuidtools',然后bundle install

后面可能多个模型创建记录都要生成ID,所以我们要单独写一个模块(模块一般写在lib目录下),在需要自动生成ID的地方引入该模块即可。


然后在模型文件引入该模块即可:


历史记录的日期也应该自动生成才行,也就是rails默认会生成的日期。不过在本例子中不会自动生成日期,因为不符合rails命名约定。
我们查看api文档,


可以看到默认生成时间的命名约定不是CreateTime而是create_at这种命名方式。我们把日期命名修改为create_at这种命名方式并重启服务器就会自动存入时间。不过对于前后端分离的这种表,如果时间字段就得是CreateTime和UpdateTime字段,那么我们要怎么自动存入日期值呢?
因为默认命名约定是来自rails框架的某个模块设定,所以我们可以找到该模块,并把该模块的默认命名约定添加上CreateTime和UpdateTime字段,把该模块引入lib目录下,这样CreateTime和UpdateTime字段也算符合新的命名约定,自动生成的日期值会自动存入。
我们查看迁移文件里面有t.timestamps null: false,那么我们找到该框架模块的模块文件,如下就是该框架的默认命名约定的两个方法


我们修改这两个方法,把其中一个默认命名约定修改为CreateTime和UpdateTime。然后把该模块文件添加到项目的lib目录下。这样在项目加载rails框架自动生成时间的模块之后,新添加的模块文件会覆盖原来的rails框架的模块。


前面我们在lib目录下面添加的模块是无法生效的,因为我们需要在如下文件添加一行代码,表示把lib目录下的所有文件都引入到项目中。因为自动插入的时间与本地相差8小数,所以我们也设置插入时间为本地时间。如下最后两行代码:


image.png

然后我们重启服务器

前面我们把历史记录表命名错误,我们直接在navicat里面把有关历史记录的这张表重命名即可


在barcode_scanner_four.html.erb页面只要在barcode_scanner_three.html.erb页面一处地方添加上&fromList=true同时把连接地址改为scanner_four,如下


image.png
  • 添加控制器动作


  • 如下select写在joins前面或者后面都是可以的


time_ago_in_words历史记录视图

有可能我们在数据表中存入的数据是本地时间,但是在视图文件读取出来的时候还是UTC时间,不过使用time_ago_in_words的时间肯定是正确的


  • 结果页面
    结果描述:
    1、一码多商品显示列表,点击列表项进入详细信息页,往barcode_histories插入ProductID记录
    2、一码一商品显示详细信息页,往barcode_histories插入Code记录
    3、历史记录页面,点击查看详细信息来到对应的详细信息页面,但不往barcode_histories插入记录

一码一商品情况:


一码多商品情况:


历史记录得到保存

image.png

历史记录页面



历史记录页面打开的详细信息页面


git add .
git commit -m "查询编码历史记录"
git push -u https://github.com/xiaohuacc/active_record.git fifth/history
Counting objects: 23, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (22/22), done.
Writing objects: 100% (23/23), 7.33 KiB | 0 bytes/s, done.
Total 23 (delta 12), reused 0 (delta 0)
remote: Resolving deltas: 100% (12/12), completed with 12 local objects.
To https://github.com/xiaohuacc/active_record.git
 * [new branch]      fifth/history -> fifth/history
Branch fifth/history set up to track remote branch fifth/history from https://github.com/xiaohuacc/active_record.git.

合并到主分支

git checkout master
git merge fifth/history
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容