切换到新的分支进行开发
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小数,所以我们也设置插入时间为本地时间。如下最后两行代码:
然后我们重启服务器
前面我们把历史记录表命名错误,我们直接在navicat里面把有关历史记录的这张表重命名即可
在barcode_scanner_four.html.erb页面只要在barcode_scanner_three.html.erb页面一处地方添加上&fromList=true同时把连接地址改为scanner_four,如下
-
添加控制器动作
-
如下select写在joins前面或者后面都是可以的
time_ago_in_words历史记录视图
有可能我们在数据表中存入的数据是本地时间,但是在视图文件读取出来的时候还是UTC时间,不过使用time_ago_in_words的时间肯定是正确的
- 结果页面
结果描述:
1、一码多商品显示列表,点击列表项进入详细信息页,往barcode_histories插入ProductID记录
2、一码一商品显示详细信息页,往barcode_histories插入Code记录
3、历史记录页面,点击查看详细信息来到对应的详细信息页面,但不往barcode_histories插入记录
一码一商品情况:
一码多商品情况:
历史记录得到保存
历史记录页面
历史记录页面打开的详细信息页面
- 因为使用joins,所以我们看到http://localhost:3000/products/barcode_history页面控制台输出没有多余的sql查询语句
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