比如有如下的一个博客:该博客存储的数据比较杂
可以存储
电影数据:
音乐数据:
商品数据:
图片数据:
软件数据:
要存储这么多的数据,表如何设计?
每种数据都有他特有的特性,例如音乐有填词人,作曲人,图片有像素。
总不可能一个表,然后每个数据的不同特性都给一个字段。
但是如果分表的话,一个总表,记录着类型和id等基本的,电影数据一个表,图片数据一个表,等等.....这样的话,如果是取出所有数据时,需要查询多张表,导致效率比较低效。
有没有什么更好的设计解决方法?
回复内容:
比如有如下的一个博客:该博客存储的数据比较杂
可以存储
电影数据:
音乐数据:
商品数据:
图片数据:
软件数据:
要存储这么多的数据,表如何设计?
每种数据都有他特有的特性,例如音乐有填词人,作曲人,图片有像素。
总不可能一个表,然后每个数据的不同特性都给一个字段。
但是如果分表的话,一个总表,记录着类型和id等基本的,电影数据一个表,图片数据一个表,等等.....这样的话,如果是取出所有数据时,需要查询多张表,导致效率比较低效。
有没有什么更好的设计解决方法?
可以用nosql,比如mongodb的document的方式存储。
不必拘泥于字段。
若題主用的是mysql5.7
, 可以把存儲數據的字段設置爲json
類型的, 如
<code>//其他數據字段... //电影数据,音乐数据等設計爲json { “move”: { }, "music" : { } //....... } </code>
分表之后前台后的逻辑是要分开写的:
前台读取的时候不要直接读取主表数据,通过具体类型的附表去关联查询主表。
后台直接读取主表信息,但是不要读取附表,只在后台列表中显示主表内的数据,有需要展示附表的数据放到详情页面去。如果真的需要展示各个附表中的某些字段的话,那么牺牲一些性能也是值得的,另外这种如果是所有附表都有的字段也要提到主表中
可以参考2楼的 但如果还是希望单一种类数据库的话可以参考wordpress的库设计...他是将非主要或者可变类型属性设计成key-value形式的副表存储...思想是和nosql一致的....只是实现用了关系型数据库来实现
或者可以用EAV结构设计,表只存数据,在其上加一层代码以满足不同类型数据的需求。
具体方法搜一下EAV就可以了,magento是用这种方法实现的网店。

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver Mac版
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。