(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的地方引入该模块即可。


(5)查询编码历史记录_第1张图片

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


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


(5)查询编码历史记录_第2张图片

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


(5)查询编码历史记录_第3张图片

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


(5)查询编码历史记录_第4张图片

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


(5)查询编码历史记录_第5张图片
image.png

然后我们重启服务器

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


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


(5)查询编码历史记录_第6张图片
image.png
  • 添加控制器动作


    (5)查询编码历史记录_第7张图片
  • 如下select写在joins前面或者后面都是可以的


    (5)查询编码历史记录_第8张图片

time_ago_in_words历史记录视图

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


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

一码一商品情况:


(5)查询编码历史记录_第10张图片

一码多商品情况:


(5)查询编码历史记录_第11张图片
(5)查询编码历史记录_第12张图片

历史记录得到保存

(5)查询编码历史记录_第13张图片
image.png

历史记录页面


(5)查询编码历史记录_第14张图片

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


(5)查询编码历史记录_第15张图片
  • 因为使用joins,所以我们看到http://localhost:3000/products/barcode_history页面控制台输出没有多余的sql查询语句
    (5)查询编码历史记录_第16张图片
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

你可能感兴趣的:((5)查询编码历史记录)