当前位置: 首页 > wzjs >正文

如何对网站做压力测试网络推广需要什么

如何对网站做压力测试,网络推广需要什么,聊城手机网站服务,苏州企业网站建设方案背景: 模拟一个简单版计算器,两位操作数运算,运算符号包括-*/,目前是把这些数据存储到了MySQL数据库中,库为cal,表名为success,如图: CREATE TABLE success (id INT AUTO_INCREMEN…

背景:

模拟一个简单版计算器,两位操作数运算,运算符号包括+-*/,目前是把这些数据存储到了MySQL数据库中,库为cal,表名为success,如图:

CREATE TABLE success (id INT AUTO_INCREMENT PRIMARY KEY,nums VARCHAR(255) NOT NULL COMMENT '用户输入的运算表达式,如1+1',result DOUBLE NOT NULL COMMENT '运算结果',spend_time BIGINT NOT NULL COMMENT '计算耗时(毫秒)',created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

输入关键字history可以进行查询操作:

 

问题分析:

  1. 这种“22+78”的nums存储是非结构化的 ,存储的是表达式字符串
  2. 还有耗时这一块,应该直接存储7即可,不要存一串描述文字
  3. 不符合三范式(3NF),表达式和结果之间存在函数依赖(result = function(nums))
  4. 扩展性差

改进方案:

使用数据库三范式设计,步骤如下:

一、首先先理解三大范式:

  1. 第一范式(1NF):每个字段都是不可分割的原子值

  2. 第二范式(2NF):满足1NF,且非主键字段完全依赖主键(针对联合主键)

  3. 第三范式(3NF):满足2NF,且消除传递依赖(非主键字段间不能有依赖)

二、从需求出发设计:

分析需求:
  • 需要记录的有:id,操作数1,运算符,操作数2,结果,耗时,创建时间

  • 主实体

    • 计算记录(cal):id、耗时、结果、创建时间

  • 子实体

    • 操作数(operand):值、位置(即第几个数)

    • 运算符(operator):符号类型(比如+-*/)

三、表设计:

场景模拟:

现在要保存「3 + 5」的运算记录:

  1. 先创建「计算记录」主表条目(生成cal_id=1)

  2. 接着要在operands表插入两条记录:

    • (cal_id=1, position=1, value=3)

    • (cal_id=1, position=2, value=5)

  3. 最后在operators表插入:

    • (cal_id=1, operator='+')

总结:三表设计方案,分别是cal、operands、operators三张表

四、三表设计(完全范式化)代码:

-- 运算记录主表
CREATE TABLE cal (id INT AUTO_INCREMENT PRIMARY KEY,spend_time BIGINT NOT NULL COMMENT '计算耗时(毫秒)',result DOUBLE NOT NULL COMMENT '计算结果',created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);-- 运算数表
CREATE TABLE operands (id INT AUTO_INCREMENT PRIMARY KEY,cal_id INT NOT NULL COMMENT '关联计算记录',position INT NOT NULL COMMENT '操作数位置(1,2,...)',param DOUBLE NOT NULL COMMENT '操作数值',FOREIGN KEY (cal_id) REFERENCES cal(id)
);-- 运算符表
CREATE TABLE operators (id INT AUTO_INCREMENT PRIMARY KEY,cal_id INT NOT NULL COMMENT '关联计算记录',operator CHAR(2) NOT NULL COMMENT '运算符,如+,-,*,/',FOREIGN KEY (cal_id) REFERENCES cal(id)
);

界面化展示三张表结构:

 

 

为什么满足三范式?
  1. 满足1NF:所有字段都是原子值

  2. 满足2NF

    • 单列主键不存在部分依赖问题

    • 外键关系完整

  3. 满足3NF

    • 消除了传递依赖(如原设计result依赖nums)

    • 各表非主键字段只依赖主键

但是这种三表设计复杂度比较高(需要多表join查询),但同时灵活性也很高(支持任意数量操作数)

这里我们虽然只是一个简单计算器没必要这么麻烦,但是主要是为了学习三范式数据库表设计,所以还是用三表设计!配合下面的时序图来理解三张表的关系!

修改之后: 

注意细节:

cal表的created_at:


下一篇再讲讲三表查询SQL怎么写!^_^

http://www.dtcms.com/wzjs/405133.html

相关文章:

  • 公司个人怎么制作网站网站到首页排名
  • 厦门网站建设seo免费涨粉工具
  • 上海景泰建设有限公司网站短视频广告投放平台
  • 手机企业网站推广免费建站网站网页
  • 制作网站首先要知道什么如何做好一个网站
  • 做b2b网站用什么架构在百度怎么免费发布广告
  • 音乐主题资源网站建设快速排名推荐
  • 国家开放大学网站的作业怎么做百度应用宝
  • 网站建设资金报告安徽seo人员
  • 哪个网站美丽乡村做的比较好中国新闻最新消息
  • 高阳网站制作免费发布推广的平台
  • 做仿牌网站空间百度助手app下载
  • 做学校网站素材图片描述优化方法
  • 路由器做网站免费seo排名网站
  • 汽车精品设计网站建设百度广告联盟收益
  • 出售网站平台友谊平台
  • 网站网站设计公司今日热点新闻事件
  • 黑龙江能源建设网站技成培训网
  • 投资我赢网seo优化网站
  • php和java做网站哪个好做外贸怎么推广
  • 高校网站建设近期情况说明在百度上做广告推广要多少钱
  • 网站内页做友链淘宝推广工具
  • 企业网站资料大全超云seo优化
  • 出口网站建设方案百度影响力排名顺序
  • 招聘网站评估怎么做郑州免费做网站
  • 网站基础建设和管理暂行办法为企业策划一次网络营销活动
  • 新疆建设职业技术学院招生信息网站seo工作流程
  • java网站开发思维导图怎样在百度上做广告
  • 如何在对方网站上做外链深圳网站建设公司
  • 视频上到什么地方可以做网站链接中文网站排名