- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有后端 PHP 和 mysql 的 android 应用搜索功能。
目前在用户按键时我正在向服务器发送请求以获取数据。 (实时建议)。
每次按键时,我都会将用户输入插入到服务器。
问题是在一天结束时,要查看用户搜索内容的统计数据非常困难,因为存在如下冗余数据。
用户搜索:Apple
移动设备 在每次按键时将请求发送到服务器,如下所示
苹果
问题是:如何从mysql中删除记录[1到4]并只保留[5]
注意:在移动应用程序中保留相同的实时搜索(按键)功能。
其他注意事项:应用正在使用 REST API 通过 HTTP POST 发送数据一次可能有 1000 名用户搜索该应用程序。 [最后一条记录可能并不总是同一查询的一部分]
我通过发送 12 个字符长度的唯一 key 以及搜索查询解决了这个问题,在一天结束时,我通过保留每个 key 的最新记录来清理查询
最佳答案
它可以通过将冗余数据保存在数据库中来帮助您。假设最初数据库中没有任何用于实时搜索的记录。
假设最终用户正在搜索术语“Apple 6s”。现在假设他输入了关键字“A”现在根据您当前的逻辑,您正在请求后端服务器将该术语保存在数据库中。
假设您的用户搜索词保存表名称目前为“user_searches”。因此,默认情况下该表是空的。当用户键入关键字“A”时,记录将插入此表中,id(主键)为 1。
下次尝试时,当用户再次键入关键字“p”时,请求将使用字符串“Ap.”发送到服务器。您不会将其保存为新记录,而是会更新已使用字符串“A”保存的上一条记录。因此记录 id 1 的新值为“Ap”
您需要更新记录 id 1,除非且直到字符串中存在空格。因此,一旦您收到字符串中的空格,您就必须插入新的记录(在我们的例子中是数据库中 ID 为 2 的第二条记录)。因此,根据这个逻辑,如果用户输入字符串“Apple 6s”,您将在数据库中获得如下记录
id 搜索术语1 个苹果2 6秒
因此,每当您将记录插入数据库时,您都必须在响应中发送该记录的最新 ID。
您必须考虑到,如果用户 A 正在搜索术语“Apple”,那么最初该用户的记录 ID 将为 1同时,如果用户B也在搜索术语“Nokia”,那么它将有记录id 2用于更新。所以你必须根据设备 ID 来跟踪搜索词。为此,您可以在 user_searches 表中再添加一列作为“deviceId”,以便您可以轻松跟踪各个设备搜索词。
希望这会对您有所帮助。
关于php - 删除相同 "KeyWord"模式的上一条记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34942792/
import csv import numpy as np from sklearn.svm import SVR import matplotlib.pyplot as plt dates = []
我在 ANTLRWorks 1.4 中有以下语法。我正在考虑在文本冒险游戏创建器中实现解析器的想法,其中用户将为他的游戏指定各种允许的命令。 grammar test; parse :
我有一个 .dat 文件,我首先想将其转换为 .csv 文件,然后根据时间绘制一些行,我的脚本如下: import pandas as pd import numpy as np from sys i
python 出现SyntaxError: non-keyword arg after keyword arg错误解决办法 前言:
我有一个我无法理解的问题,因此在删除按钮中,尝试在创建按钮后将其删除的地方,出现以下错误: Delete=Button(root,text='Delete',command=lambda : S.pa
我想将某个函数作为线程运行,但我得到了 SyntaxError: non-keyword arg after keyword arg 我不明白为什么: #!/usr/bin/env python im
我试图在 scrappy 中抓取多个页面,我的函数确实返回第一个起始网址,但我无法设法使蜘蛛的规则生效。 这是我到目前为止所拥有的: import scrapy from scrapy.contrib
我正在使用 emeditor,我试图从法语维基百科转储 .xml 文件(20GB,3.38 亿行,总共 480 万篇文章)中分离出大约 200 万篇包含 keyword3 的文章。我想将文本包含在 2
发布表如下所示: publications ============ id title etc ... 关键字表如下所示: keywords ======== id name etc ... keyw
我有这个功能: def crypting(self, client, access_token, client_id, client_secret, oauth_scope, redirect_uri
我正在学习 Rails,但在以下代码中出现语法错误 unexpected keyword else, expected keyword end,我不知道为什么。
我正在一个网站上工作,我必须在数据库中搜索根域上/之后的字符串。我在文档中找不到任何有关它的信息。我正在尝试使其与 Iron Router 一起使用,但任何其他建议都会起作用。 感谢您的帮助! 编辑:
我刚刚找到有关 apache solr 的信息,并且在我成功安装了带有 Tomcat 的 apache Solr 之后。然后我开始使用 Apache Solr 进行搜索。 但我对 Apache Sol
我是 Angular JS 新手。我无法弄清楚过滤器如何仅对对象中的名称起作用,而不是对对象中的电话键起作用。就好像我们在 ng-model 中仅使用关键字一样,它将过滤范围中定义的对象中的名称和电话
当我运行以下代码行时,我试图将按钮按下绑定(bind)到 Tkinter 中的函数 get = Button(root, lambda: ChangeColour(boxes[1][2], boxes
response = requests.post("http://api.bf3stats.com/pc/player/", data = player, opt) 在 python IDLE 中运行
这是我正在操作的更新查询。此处错误“set data = :updateValue”,数据是 Dynamo DB 的保留关键字。我想我应该在这里使用 update ExpressionAttribut
根据维基百科,二元运算符 ?:是 colloquially referred to as the Elvis operator due to its resemblance to an emotico
我知道 AND 词定义了二进制 and ...但什么定义了逻辑and ? 最佳答案 同一个字,AND , 也用于逻辑与。但是这两个输入值要AND推荐为格式良好的标志 ; 真和 假 由两个值表示,位全部
反引号运算符的固定性是什么? 例如在 Real World Haskell 的这段代码中: ghci> (1+) `fmap` [1,2,3] ++ [4,5,6] [2,3,4,4,5,6] 很明显
我是一名优秀的程序员,十分优秀!