- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Users table
user_id
pic_url
name
friends table
auto_id
userid
friendid
status
actions table
auto_id
userid
type
subject
body
datetime
我想创建一个显示更新的 friend 更新流,可以是博客文章、状态更改,但应该只显示来自已登录用户的 friend 的更新
这是我的想法,但我的用户群非常大,所以性能是必须的,有更好的方法吗?请告诉我
SELECT u.user_id, u.pic_url, u.name, a.auto_id, a.userid, a.type, a.subject, a.body, a.datetime
FROM actions AS a
LEFT JOIN users AS u ON u.auto_id=a.userid
LEFT JOIN friends AS f ON f.userid=a.userid
WHERE f.friendid=1 //1 would be my user ID
AND f.status=active
请帮助我认为这是不正确的。
假设有 50,000 个用户,我的用户 ID 是 #1,我是 20,000 个用户的 friend ,它应该返回我是 friend 的用户发布的操作表中的所有条目,还需要修改以包含操作来 self 自己
我听说有人谈论使用某种哈希表来加快查找速度,这样的事情在这里可能吗?
感谢您的帮助
最佳答案
I have heard some people talki about using some sort of hash table for faster lookups would something like that be possible here?
它叫做 index ,并且您应该向您计划使用 JOIN 的每一列添加一个(或匹配显式约束,如 >, >=, =, <=, <
或 IN ()
子句,该子句仅匹配指定列表中的项目)。这样数据库服务器就可以直接跳转到索引中的正确条目,而不必对所有表行进行强力搜索。它就像一本书中的索引。如果您想在一本书中找到名字“Knuth”出现的页面,您有两种选择。如果这本书有索引,你会查看索引并希望名字在那里。如果这本书没有索引,您将不得不自己通读整本书,这会花费更长的时间。
如果您关心排序/排序(或进行任何类型的相对数字/字符串比较),它应该是一个排序索引。否则它可以是哈希表索引,这对于有很多行的表来说更快,但不包含排序信息。这些类型的详细信息可能具有不同的语法/选项,具体取决于所使用的数据库服务器软件类型。**(请参阅下面的注释)
请注意,主键已经有一个自动生成的索引,因此您不必自己添加一个。另请注意,如果您有一个多列主键,例如(State, City, Zipcode) 那么在主键的最左边的子集上实际上会有索引,例如您可以免费获得 State、(State,City) 和 (State,City,Zipcode) 的索引,但是如果您想加入 Zipcode 或 City 或 (City,Zipcode),则需要在中创建自己的索引除了主键提供的那些。
在你的例子中,看起来你应该在这些列上有索引(我已经 *-ed 我假设已经是主键的列)。除非您对用户 ID 的数字顺序有任何重要意义,否则它们将是哈希表索引的良好候选者。
Users.user_id*
Friends.user_id
Friends.friend_id
Friends.active
Actions.user_id
**对于 MySQL,您向 CREATE INDEX statement 添加一个子句上面写着 USING HASH 用于哈希表索引,或 USING BTREE(用于排序索引)...忽略 RTREE,因为它们用于空间数据。另请注意,MySQL 不允许在常用存储引擎 InnoDB 和 MyISAM 上使用 HASH 索引。真正需要高性能的大型数据集可能需要将数据镜像到具有 HASH 索引的内存表上。有了 50,000 行,您可能不需要担心; BTREE 的搜索时间是 O(log n) 而 HASH 是 O(1) 并且可能没有太大区别。 BTREE 非常宽,设计得不深;要在搜索步骤中要求进行一次额外的比较,您可能需要将行数增加 10 或 100 倍。
关于php - 需要有关 mysql 连接的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1175227/
据我所知,标准 jQuery“切换”功能在 jQuery mobile 中不起作用 - 这是正确的吗?如果是这样,还有其他有效的方法吗?我想做的就是打开和关闭“播放”按钮。所以按钮 ID 是“play
他们要求我提供一个“切换按钮”来打开和关闭集群有人可以帮助我实现集群的打开/关闭吗? 注意:加载超过30,000点 最佳答案 创建两层,一层有标记聚类,一层没有标记聚类,并将它们添加到传单控件中。例如
所以我想让我的 Python Gtk 小窗口有 2 个开关。当一个开关打开时,另一个开关关闭,反之亦然。我不太清楚如何控制这两个开关。如果有人能引导我走向正确的方向,我将不胜感激。 #!/usr/bi
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我为我的 android 应用程序集成了推送通知,我想为任何 android 手机/标签打开/关闭推送通知,任何人都可以帮助我... protected void onPostExecute(Blog
我遇到无法更改的问题 Switch运行时的 textOn/textOff 内容。这意味着,绑定(bind)到简单按钮(用于测试目的)的以下代码不起作用: private int _counter =
我正在开发一个应用程序来测试 iPhone 屏幕是关闭还是打开,我尝试了堆栈溢出中指定的加速度计代码,它在屏幕开启状态下运行良好,但是当我关闭屏幕时,加速度计没有停用。 所以我开始怀疑当屏幕关闭时加速
我想将前置闪光灯设置为自动闪光灯,因此前置摄像头不支持闪光灯,所以我必须将一个 View 设置为白色,以便它作为闪光灯使用,现在我的问题是如果用户设置了怎么办闪光模式自动?当我必须显示 Flash V
我有一个表,其中每隔一个表行都有一个类名“hideme”。在我制作的 css 文件中 .hideme { display:none} 隐藏行包含一个密码字段和一个按钮。在任何给定时间只能显示一个隐藏行
我正在尝试使用 css 切换复选框,使用开/关图像进行切换。但是它并没有发生,fiddle . I agree input[type=checkbox] { display:non
我正在为智能手机编写一个网站。我使用 javascript: navigator.geolocation.getCurrentPosition 来获取位置。 尽管如此,在执行此功能之前,我需要检测 G
如何在我的 Android 应用程序中以编程方式设置数据漫游开/关? 最佳答案 提前为重新打开一个死帖而道歉,但我已经通过调用这个可执行文件设法实现了它: su -c settings put glo
我正在用 java 编程,但我也可以采用 C++(甚至伪)代码,没问题。这是我的意思: 我有一个类似播放列表的东西,例如 List lsMyPlaylist .现在我想给用户洗牌的机会,然后再回到有序
我正在寻找最好的、最具可扩展性的方式来跟踪大量的开/关。开/关适用于项目,编号从 1 到大约 6000 万。 (在我的例子中,开/关是成员(member)的书是否被编入索引,这是一个单独的过程。) 开
我发现下面的代码可以以被动的方式做到这一点。 context.registerReceiver(this.ScreenOffReceiver, new IntentFilter(Intent.ACTI
我有一个脚本,我定期运行以使用 Applescript 打开/关闭灰度。它在 High Sierra 上运行良好,但当我在 Mojave 使用它时抛出异常。 tell application "Sys
如果我启动一个内联 Matplotlib 的 IPython Notebook,有没有办法随后绘制一个图形,以便它以“标准”、非内联的方式显示,而无需在没有内联命令的情况下重新加载笔记本? 我希望能够
如何使用Android中的CheckBoxPreference切换整个系统的声音,振动,数据连接和wifi? 我想在我的应用程序中正在运行 Activity 时禁用这些功能。 最佳答案 我想到了。 在
我想在我的网站上创建一个维护模式,我想放置一个只有管理员才能看到的按钮来打开/关闭维护模式。 这允许管理员继续查看网络,但其他访问者则不能。 我读过有关 catchAllRequest 的内容,创建一
如何检测客户端或服务器端 (ASP.NET) 的浏览器缓存设置。基本上尝试检测用户浏览器是否打开或关闭了缓存。如果关闭,我想将他们重定向到一个包含错误消息的页面,告诉他们打开它。这可能吗? 最佳答案
我是一名优秀的程序员,十分优秀!