视图、索引、存储过程一个常规的 App 后台或者简单的网站这些是必须的吗?

本贴最后更新于 2325 天前,其中的信息可能已经时移世改

目前维护公司的一个库房管理系统,之前对数据库了解不是很多,我想问下各位视图,索引,存储过程这些东西对于一个 App 后台或者是简单的网站不用不行吗?

  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 739 回帖 • 1 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    9396 引用 • 42824 回帖 • 112 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250 1 赞同
    1. 索引肯定是需要的
    2. 视图看查询场景的复杂度,大部分业务场景应该都不需要
    3. 存储过程能不用就不用

    现代应用基本都是微服务架构,已经按业务场景进行了垂直拆分,所以每个服务的实现不会太复杂。传统面向数据库架构的 MIS 系统有些也在往服务化上迁移,不过也有强依赖数据库的,比如 Oracle、SAP 的 ERP 系统,很多实现都是在数据库层来做。

    综上,简单的网站或者 APP 后端不需要用视图或者存储过程,用了的话反而会增加维护成本,甚至给接盘侠留下很多深不见底的坑。

    1 回复
  • 用了存储过程,你就站在坑的边缘了。

    1 回复
  • EvilCodes
    作者

    我接收了离职人员的一个项目负责维护,各种坑,数据库数据出错都不敢动,关联性太强,牵一发而动全身

  • EvilCodes
    作者

    我就是接盘侠

    1 回复
  • 88250

    还有一个坑是触发器,那叫一个酸爽。

    3 回复
  • 就在前几天,用的 Oracle ,报外键关联的一条数据没有了,找啊找啊找,终于定位到却数据的 那个 后台实体类 ,数据库没有强关联,但是 用 hibernate 强关联的,找到 关联的那个 实体 ,通过 hbm 配置找到表,以为 OK 了,结果 去数据库看,这个 实体对应了一个视图!!!!! ,然后打开视图,又是关联了 N 表~ 甚至有 union all 的数据,我他妈怎么找的到 缺了哪条数据……

  • EvilCodes
    作者

    我打算用传统的方式重构项目,但我们领导是一个 sqlserver 狂热者,他说我的想法不行,用 sql 处理业务逻辑,存储 过程才是王道,用他那不可一世的权威,我很无语。

    1 回复
  • EvilCodes
    作者

    他根本不懂 Java 不懂安卓不懂 JavaWeb 开发,只是 sqlserver 玩的 6 就要求必须按他的思路来

    1 回复
  • 88250

    和他没法讨论的话就按他的思路来吧,干不动了再说。

  • Eddie

    很多传统的软件开发公司部门主管都是那些精通数据库的上了年纪的人,因为他们那个年代项目的瓶颈基本就是数据库,没有缓存,分布式的说法。

    1 回复
  • 88250 1

    这个年代的瓶颈也是数据库,你看上个月 GitHub 的数据库都出事了。计算、网络、存储这三者在分布式架构上,计算的分布最简单,网络分布主要靠设备,存储的分布就很难搞,目前能用的基本都是商业解决方案。数据中心异地多活也一直是业界难题,各种商业解决方案各有利弊。

请输入回帖内容 ...
EvilCodes
我的世界,我的代码,我的逻辑。

推荐标签 标签

  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 81 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖 • 1 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 663 关注
  • V2Ray
    1 引用 • 15 回帖 • 1 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 53 关注
  • OneNote
    1 引用 • 3 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    85 引用 • 165 回帖 • 1 关注
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    226 引用 • 476 回帖
  • 分享

    有什么新发现就分享给大家吧!

    247 引用 • 1794 回帖
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 413 关注
  • Access
    1 引用 • 3 回帖 • 6 关注
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    133 引用 • 884 回帖
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    31 引用 • 108 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    6 引用 • 26 回帖 • 547 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖 • 1 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1440 引用 • 10067 回帖 • 490 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 76 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 56 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    108 引用 • 295 回帖
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    5 引用 • 34 回帖
  • 倾城之链
    23 引用 • 66 回帖 • 158 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    93 引用 • 901 回帖
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 701 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 690 关注
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    93 引用 • 113 回帖
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注