首页 后端开发 php教程 数据库的设计解决办法

数据库的设计解决办法

Jun 13, 2016 pm 01:07 PM
linux memcache memcached nosql

数据库的设计
1.评论:如何保证用户购买过商品才可以评论,必须只能评论一次,1件商品评论一次,当再次购买的时候,可以继续评论一次,就如:淘宝网的评论系统,说说你的思路.

2.文章页浏览次数:浏览的次数是如何统计的,难道其它的网站也是用数据库做的吗?每次浏览+1,如果量大的话,是不是给数据库系统造成压力? 如果不是,那是用什么统计.



------解决方案--------------------
2.日志文件追加写实现的,linux下专门开了一个服务,不停地追加,定时处理数据取的不同操作的访问量,最后生成excel通过自动邮件交给数据部门。这么一个流程。。。
1的话方法多了去了,不过效率、稳定什么的就不好说了,没试过。肯定是和数据库设计有关吧。
------解决方案--------------------
我回答你第2个问题,如果瓶颈在数据库那么可以采取memcache中间缓存的方式来缓存.每一个小时或者半个小时统一更新一次数据库.
------解决方案--------------------
1.评论:如何保证用户购买过商品才可以评论,必须只能评论一次,1件商品评论一次,当再次购买的时候,可以继续评论一次,就如:淘宝网的评论系统,说说你的思路.
这个问题比较简单,用户购买的时候是有订单的,评论之前查看一下这个用户是否在订单库里购买过该商品,如果有则查询一下购买数量,这样就可以限制评论次数了,评论完毕之后在订单库里做一个已经评论过的标记.

2.文章页浏览次数:浏览的次数是如何统计的,难道其它的网站也是用数据库做的吗?每次浏览+1,如果量大的话,是不是给数据库系统造成压力? 如果不是,那是用什么统计.
这个问题,我的做法是:采用缓存的方式,最常见的缓存方法是memcache和文件缓存,memcache好一点,文件缓存会给服务器造成IO的压力,推荐使用memcahce,当用户浏览的时候先读取缓存中是否有该文章的浏览次数记录,如果没有找到记录则建立针对该文章的一条记录,同时计数为1,下一次有人访问的时候再次读取缓存,让计数加1,当该文章的计数达到10次(次数你可以自定义)的时候就清理掉缓冲中该文章的浏览计数,同时把次数写入数据库.
基本原理就是:不到10次就存入缓存,到了10次清理缓存并更新数据库中的浏览次数.这样就是浏览数达到10次再重新操作一次数据库,有效的降低了数据库的压力.
------解决方案--------------------
首先想说的是数据库比你想象的要强大得多. 


------解决方案--------------------
1.评论:如何保证用户购买过商品才可以评论,必须只能评论一次,1件商品评论一次,当再次购买的时候,可以继续评论一次,就如:淘宝网的评论系统,说说你的思路.

购买的时候会生成一个订单id对吧?把评论表和这个订单id对应上,每个id只能在评论表内评论一次

2.文章页浏览次数:浏览的次数是如何统计的,难道其它的网站也是用数据库做的吗?每次浏览+1,如果量大的话,是不是给数据库系统造成压力? 如果不是,那是用什么统计.

小应用可以直接数据库,大的话可以memcached,有个自增的接口,然后定时dump数据到sql即可

------解决方案--------------------
为什么总是想象数据库是不堪一击的呢?
如果用文件做载体,那么关系型数据库也是用文件存储数据的
如果用 memcached 作载体,那么 nosql 也是基于内存的

简单的操作文件或内存,貌似速度要快些。但你还需要用大量的代码来管理和解决冲突
综合效率就不如直接数据库了

------解决方案--------------------

探讨

首先想说的是数据库比你想象的要强大得多.
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1666
14
CakePHP 教程
1426
52
Laravel 教程
1328
25
PHP教程
1273
29
C# 教程
1253
24
Linux体系结构:揭示5个基本组件 Linux体系结构:揭示5个基本组件 Apr 20, 2025 am 12:04 AM

Linux系统的五个基本组件是:1.内核,2.系统库,3.系统实用程序,4.图形用户界面,5.应用程序。内核管理硬件资源,系统库提供预编译函数,系统实用程序用于系统管理,GUI提供可视化交互,应用程序利用这些组件实现功能。

git怎么查看仓库地址 git怎么查看仓库地址 Apr 17, 2025 pm 01:54 PM

要查看 Git 仓库地址,请执行以下步骤:1. 打开命令行并导航到仓库目录;2. 运行 "git remote -v" 命令;3. 查看输出中的仓库名称及其相应的地址。

notepad怎么运行java代码 notepad怎么运行java代码 Apr 16, 2025 pm 07:39 PM

虽然 Notepad 无法直接运行 Java 代码,但可以通过借助其他工具实现:使用命令行编译器 (javac) 编译代码,生成字节码文件 (filename.class)。使用 Java 解释器 (java) 解释字节码,执行代码并输出结果。

sublime写好代码后如何运行 sublime写好代码后如何运行 Apr 16, 2025 am 08:51 AM

在 Sublime 中运行代码的方法有六种:通过热键、菜单、构建系统、命令行、设置默认构建系统和自定义构建命令,并可通过右键单击项目/文件运行单个文件/项目,构建系统可用性取决于 Sublime Text 的安装情况。

Linux的主要目的是什么? Linux的主要目的是什么? Apr 16, 2025 am 12:19 AM

Linux的主要用途包括:1.服务器操作系统,2.嵌入式系统,3.桌面操作系统,4.开发和测试环境。Linux在这些领域表现出色,提供了稳定性、安全性和高效的开发工具。

laravel安装代码 laravel安装代码 Apr 18, 2025 pm 12:30 PM

要安装 Laravel,需依序进行以下步骤:安装 Composer(适用于 macOS/Linux 和 Windows)安装 Laravel 安装器创建新项目启动服务访问应用程序(网址:http://127.0.0.1:8000)设置数据库连接(如果需要)

git软件安装 git软件安装 Apr 17, 2025 am 11:57 AM

安装 Git 软件包括以下步骤:下载安装包运行安装包验证安装配置 Git安装 Git Bash(仅限 Windows)

如何设置重要的 Git 配置全局属性 如何设置重要的 Git 配置全局属性 Apr 17, 2025 pm 12:21 PM

自定义开发环境的方法有很多种,但全局 Git 配置文件是最有可能用于自定义设置(例如用户名、电子邮件、首选文本编辑器和远程分支)的一种。以下是您需要了解的有关全局 Git 配置文件的关键事项。

See all articles