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

有个做h手游的网站如何建立自己的网页

有个做h手游的网站,如何建立自己的网页,中国装饰公司排名,高端网站制作的公司大家好,我是捡田螺的小男孩。 昨天一位粉丝,咨询了一个并发的问题~ 我提供了一个乐观锁兜底的方案,然后发现他们的表,都没有加version字段的,我想到,这不是表设计通用字段嘛。因此,本文跟大家聊聊&#xf…

大家好,我是捡田螺的小男孩。

昨天一位粉丝,咨询了一个并发的问题~ 我提供了一个乐观锁兜底的方案,然后发现他们的表,都没有加version字段的,我想到,这不是表设计通用字段嘛。因此,本文跟大家聊聊,设计表的时候,有哪些经验准则。

公众号:捡田螺的小男孩

  1. 设计表时,尽量都有这几个通用字段
    表必备一般来说,或具备这几个字段:

id:主键,一个表必须得有主键,必须
create_time:创建时间,必须
modifed_time: 修改时间,必须,更新记录时,就更新它。
version : 数据记录的版本号,一般用于乐观锁,非必须
modifier :修改人,非必须
creator :创建人,非必须
图片

  1. 每个字段都要有注释,尤其涉及枚举这些时
    我们在设计表的时候,每个字段,都要写上注释哈,尤其涉及到一个枚举字段的时候,更要把每个枚举值写出来,后面如果有变更,也要维护到这里来~

反例:

CREATE TABLE order_tab (
id INT AUTO_INCREMENT PRIMARY KEY,
order_id BIGINT UNIQUE,
user_id BIGINT NOT NULL,
total_amount DECIMAL(10, 2) NOT NULL,
status VARCHAR(20) NOT NULL DEFAULT ‘PENDING’,
payment_status VARCHAR(20) DEFAULT ‘not_paid’,
version INT DEFAULT 0,
created_time DATETIME,
updated_time DATETIME,
creator VARCHAR(255),
modifier VARCHAR(255)
);
正例:

CREATE TABLE order_tab (
id BIGINT AUTO_INCREMENT PRIMARY KEY COMMENT ‘订单项的唯一标识符,自增主键’,
order_id BIGINT UNIQUE COMMENT ‘订单的唯一标识符,在整个系统中唯一’,
user_id BIGINT NOT NULL COMMENT ‘用户的唯一标识符,关联到用户表’,
total_amount DECIMAL(10, 2) NOT NULL COMMENT ‘订单的总金额,精确到小数点后两位’,
status VARCHAR(20) NOT NULL DEFAULT ‘PENDING’ COMMENT ‘订单的状态,例如:PENDING(待处理)、COMPLETED(已完成)等’,
payment_status VARCHAR(20) DEFAULT ‘not_paid’ COMMENT ‘订单的支付状态,如:not_paid(未支付)、paid(已支付)等’,
version INT DEFAULT 0 COMMENT ‘乐观锁版本号,用于并发控制’,
created_time DATETIME COMMENT ‘订单的创建时间’,
updated_time DATETIME COMMENT ‘订单的最后一次更新时间’,
creator VARCHAR(255) COMMENT ‘订单的创建者,通常记录创建订单的用户或系统的用户名’,
modifier VARCHAR(255) COMMENT ‘订单的修改者,通常记录最后修改订单的用户或系统的用户名’
);
3. 命名规范
数据库表名、字段名、索引名等都需要命名规范,可读性高(一般要求用英文),让别人一看命名,就知道这个字段表示什么意思。

比如一个表的账号字段,反例如下:

acc_no,1_acc_no,zhanghao
正例:

account_no,account_number
表名、字段名必须使用小写字母或者数字,禁止使用数字开头,禁止使用拼音,并且一般不使用英文缩写。
主键索引名为pk_字段名;唯一索引名为uk_字段名;普通索引名则为idx_字段名。
4. 选择合适的字段类型
设计表时,我们需要选择合适的字段类型,比如:

尽可能选择存储空间小的字段类型,就好像数字类型的,从tinyint、smallint、int、bigint从左往右开始选择
小数类型如金额,则选择 decimal,禁止使用 float 和 double。
如果存储的字符串长度几乎相等,使用 char 定长字符串类型。
varchar是可变长字符串,不预先分配存储空间,长度不要超过5000。
如果存储的值太大,建议字段类型修改为text,同时抽出单独一张表,用主键与之对应。
同一表中,所有varchar字段的长度加起来,不能大于65535. 如果有这样的需求,请使用TEXT/LONGTEXT 类型。
5. 主键设计要合理
主键设计的话,最好不要与业务逻辑有所关联。有些业务上的字段,比如身份证,虽然是唯一的,一些开发者喜欢用它来做主键,但是不是很建议哈。主键最 好是毫无意义的一串独立不重复的数字,比如UUID,又或者Auto_increment自增的主键,或者是雪花算法生成的主键等等;

图片

6.选择合适的字段长度
先问大家一个问题,大家知道数据库字段长度表示字符长度还是字节长度嘛?

其实在mysql中,varchar和char类型表示字符长度,而其他类型表示的长度都表示字节长度。比如char(10)表示字符长度是10, 而bigint(4)表示显示长度是4个字节,但是因为bigint实际长度是8个字节,所以bigint(4)的实际长度就是8个字节。

我们在设计表的时候,需要充分考虑一个字段的长度,比如一个用户名字段(它的长度5~20个字符),你觉得应该设置多长呢?可以考虑设置为 username varchar(32)。字段长度一般设置为2的幂哈(也就是2的n次方)。

  1. 优先考虑逻辑删除,而不是物理删除
    什么是物理删除?什么是逻辑删除?

物理删除:把数据从硬盘中删除,可释放存储空间
逻辑删除:给数据添加一个字段,比如is_deleted,以标记该数据已经逻辑删除。
物理删除就是执行delete语句,如删除account_no =‘666’的账户信息SQL如下:

delete from account_info_tab whereaccount_no =‘666’;
逻辑删除呢,就是这样:

update account_info_tab set is_deleted = 1 where account_no =‘666’;
为什么推荐用逻辑删除,不推荐物理删除呢?

为什么不推荐使用物理删除,因为恢复数据很困难
物理删除会使自增主键不再连续
核心业务表 的数据不建议做物理删除,只适合做状态变更。
8. 一张表的字段不宜过多
我们建表的时候,要牢记,一张表的字段不宜过多哈,一般尽量不要超过20个字段哈。笔者记得上个公司,有伙伴设计开户表,加了五十多个字段。。。

如果一张表的字段过多,表中保存的数据可能就会很大,查询效率就会很低。因此,一张表不要设计太多字段哈,如果业务需求,实在需要很多字段,可以把一张大的表,拆成多张小的表,它们的主键相同即可。

当表的字段数非常多时,可以将表分成两张表,一张作为条件查询表,一张作为详细内容表 (主要是为了性能考虑)。

  1. 尽可能使用not null定义字段
    如果没有特殊的理由, 一般都建议将字段定义为 NOT NULL 。

为什么呢?

首先, NOT NULL 可以防止出现空指针问题。
其次,NULL值存储也需要额外的空间的,它也会导致比较运算更为复杂,使优化器难以优化SQL。
NULL值有可能会导致索引失效
如果将字段默认设置成一个空字符串或常量值并没有什么不同,且都不会影响到应用逻辑, 那就可以将这个字段设置为NOT NULL。
10. 设计表时,评估哪些字段需要加索引
首先,评估你的表数据量。如果你的表数据量只有一百几十行,就没有必要加索引。否则设计表的时候,如果有查询条件的字段,一般就需要建立索引。但是索引也不能滥用:

索引也不要建得太多,一般单表索引个数不要超过5个。因为创建过多的索引,会降低写得速度。
区分度不高的字段,不能加索引,如性别等
索引创建完后,还是要注意避免索引失效的情况,如使用mysql的内置函数,会导致索引失效的
索引过多的话,可以通过联合索引的话方式来优化。然后的话,索引还有一些规则,如覆盖索引,最左匹配原则等等。。
假设你新建一张用户表,如下:

CREATE TABLE user_info_tab (
id int(11) NOT NULL AUTO_INCREMENT,
user_id int(11) NOT NULL,
age int(11) DEFAULT NULL,
name varchar(255) NOT NULL,
create_time datetime NOT NULL,
modifed_time datetime NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
对于这张表,很可能会有根据user_id或者name查询用户信息,并且,user_id是唯一的。因此,你是可以给user_id加上唯一索引,name加上普通索引。

CREATE TABLE user_info_tab (
id int(11) NOT NULL AUTO_INCREMENT,
user_id int(11) NOT NULL,
age int(11) DEFAULT NULL,
name varchar(255) NOT NULL,
create_time datetime NOT NULL,
modifed_time datetime NOT NULL,
PRIMARY KEY (id),
KEY idx_name (name) USING BTREE,
UNIQUE KEY un_user_id (user_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
11. 避免使用MySQL保留字
如果库名、表名、字段名等属性含有保留字时,SQL语句必须用反引号来引用属性名称,这将使得SQL语句书写、SHELL脚本中变量的转义等变得非常复杂。

因此,我们一般避免使用MySQL保留字,如select、interval、desc等等

  1. 一般都选择INNODB存储引擎
    建表是需要选择存储引擎的,我们一般都选择INNODB存储引擎,除非读写比率小于1%, 才考虑使用MyISAM 。

有些小伙伴可能会有疑惑,不是还有MEMORY等其他存储引擎吗?什么时候使用它呢?其实其他存储引擎一般除了都建议在DBA的指导下使用。

我们来复习一下这MySQL这三种存储引擎的对比区别吧:

图片

  1. 选择合适统一的字符集
    数据库库、表、开发程序等都需要统一字符集,通常中英文环境用utf8。

MySQL支持的字符集有utf8、utf8mb4、GBK、latin1等。

utf8:支持中英文混合场景,国际通过,3个字节长度
utf8mb4: 完全兼容utf8,4个字节长度,一般存储emoji表情需要用到它。
GBK :支持中文,但是不支持国际通用字符集,2个字节长度
latin1:MySQL默认字符集,1个字节长度
14. 时间的类型选择
我们设计表的时候,一般都需要加通用时间的字段,如create_time、modified_time等等。那对于时间的类型,我们该如何选择呢?

对于MySQL来说,主要有date、datetime、time、timestamp 和 year。

date :表示的日期值, 格式yyyy-mm-dd,范围1000-01-01 到 9999-12-31,3字节

time :表示的时间值,格式 hh:mm:ss,范围-838:59:59 到 838:59:59,3字节

datetime:表示的日期时间值,格式yyyy-mm-dd hh:mm:ss,范围1000-01-01 00:00:00到9999-12-31 23:59:59```,8字节,跟时区无关

timestamp:表示的时间戳值,格式为yyyymmddhhmmss,范围1970-01-01 00:00:01到2038-01-19 03:14:07,4字节,跟时区有关

year:年份值,格式为yyyy。范围1901到2155,1字节 推荐优先使用datetime类型来保存日期和时间,因为存储范围更大,且跟时区无关。

  1. 安全性考虑
    数据加密:敏感信息,如用户密码,应进行加密存储。如果是手机号、邮箱这些,则建议脱敏

文章转载自:
http://dinncooakum.tqpr.cn
http://dinncodiomede.tqpr.cn
http://dinncossa.tqpr.cn
http://dinncoinexpensive.tqpr.cn
http://dinncodiorite.tqpr.cn
http://dinncoscarfweld.tqpr.cn
http://dinncoempiriocriticism.tqpr.cn
http://dinncocapitao.tqpr.cn
http://dinnconewmown.tqpr.cn
http://dinncoensorcellment.tqpr.cn
http://dinncopurificatory.tqpr.cn
http://dinncojohnny.tqpr.cn
http://dinncoplumbaginous.tqpr.cn
http://dinncosonderclass.tqpr.cn
http://dinncomatrimony.tqpr.cn
http://dinncomadrilene.tqpr.cn
http://dinncowalhalla.tqpr.cn
http://dinncosalerno.tqpr.cn
http://dinncofairily.tqpr.cn
http://dinncosubemployed.tqpr.cn
http://dinncopetunia.tqpr.cn
http://dinncoslangster.tqpr.cn
http://dinncokilchu.tqpr.cn
http://dinncofarceur.tqpr.cn
http://dinncomesa.tqpr.cn
http://dinncotoccata.tqpr.cn
http://dinncocurtness.tqpr.cn
http://dinncopoignant.tqpr.cn
http://dinncomompei.tqpr.cn
http://dinncouncredited.tqpr.cn
http://dinncoknowledgable.tqpr.cn
http://dinncorigmarole.tqpr.cn
http://dinncobraid.tqpr.cn
http://dinncopotatotrap.tqpr.cn
http://dinncocommercially.tqpr.cn
http://dinncopinny.tqpr.cn
http://dinncojudoman.tqpr.cn
http://dinnconeedle.tqpr.cn
http://dinncospicate.tqpr.cn
http://dinncochronometric.tqpr.cn
http://dinncodiadelphous.tqpr.cn
http://dinncomegatanker.tqpr.cn
http://dinncocrosstie.tqpr.cn
http://dinncotracheobronchial.tqpr.cn
http://dinncoloamy.tqpr.cn
http://dinncocodeclination.tqpr.cn
http://dinncoresistive.tqpr.cn
http://dinncocull.tqpr.cn
http://dinncoforebear.tqpr.cn
http://dinncounsugared.tqpr.cn
http://dinncosupportable.tqpr.cn
http://dinncoselangor.tqpr.cn
http://dinncobiocenosis.tqpr.cn
http://dinncocorrie.tqpr.cn
http://dinncoumbrageously.tqpr.cn
http://dinncocanonicity.tqpr.cn
http://dinncoincurvate.tqpr.cn
http://dinncoantibacterial.tqpr.cn
http://dinncoshower.tqpr.cn
http://dinncounfenced.tqpr.cn
http://dinncorommany.tqpr.cn
http://dinncomonazite.tqpr.cn
http://dinncodecaliter.tqpr.cn
http://dinncocolacobiosis.tqpr.cn
http://dinncogroundskeeping.tqpr.cn
http://dinncoeelspear.tqpr.cn
http://dinncojewel.tqpr.cn
http://dinncodropwort.tqpr.cn
http://dinncoavertible.tqpr.cn
http://dinncopolyanthus.tqpr.cn
http://dinncophotocopy.tqpr.cn
http://dinncomagnolia.tqpr.cn
http://dinncopnp.tqpr.cn
http://dinncoearcap.tqpr.cn
http://dinncolysate.tqpr.cn
http://dinncolawlike.tqpr.cn
http://dinncoregulus.tqpr.cn
http://dinncoastrological.tqpr.cn
http://dinncophotoengraving.tqpr.cn
http://dinncounfearing.tqpr.cn
http://dinncosid.tqpr.cn
http://dinncodiaphanometer.tqpr.cn
http://dinncoseismetic.tqpr.cn
http://dinncoplaygoer.tqpr.cn
http://dinncomarasmic.tqpr.cn
http://dinncomirabilite.tqpr.cn
http://dinncoescarpment.tqpr.cn
http://dinnconebuchadnezzar.tqpr.cn
http://dinncopromontoried.tqpr.cn
http://dinncopraxiology.tqpr.cn
http://dinncoporkbutcher.tqpr.cn
http://dinncogrindery.tqpr.cn
http://dinncoscarify.tqpr.cn
http://dinncohydrobiology.tqpr.cn
http://dinncoedwin.tqpr.cn
http://dinncofrad.tqpr.cn
http://dinncoinspectoral.tqpr.cn
http://dinncohuppah.tqpr.cn
http://dinncoanthrosphere.tqpr.cn
http://dinncophototonus.tqpr.cn
http://www.dinnco.com/news/115994.html

相关文章:

  • 沧州市网络公司seo必备工具
  • 微站图片杭州网站推广优化
  • 平顶山做网站哪家好23岁老牌网站
  • 网站编程培训机构sem和seo是什么
  • 怎样设计自己网站域名seo推广沧州公司电话
  • 立创商城网站优化服务
  • 游戏代理是怎么赚钱的如何代理游戏china东莞seo
  • 精品课程网站开发关键技术所有的竞价托管公司
  • 温州市住房和城乡建设厅网站域名关键词排名查询
  • 六安网站制作多少钱全球网站访问量排名
  • 呼和浩特哪里做网站找广告商的平台
  • 简单响应式网站设计代码百度搜索关键词排名人工优化
  • 黄页企业名录seo的基本步骤
  • 工具类网站开发源码时代培训机构官网
  • 网站设计中遇到的问题真实的网站制作
  • 龙口做网站百度识图查另一半情头
  • 南阳卧龙区网站建设哪家好社交媒体营销策略有哪些
  • 四川移动网站建设最新今日头条
  • 深圳网站的做网站公司搜图片找原图
  • python做网站好用吗企业网站seo平台
  • 国际物流网站搜索引擎优化目标
  • 做好公众号 网站建设爱站seo工具包官网
  • 网站301是什么长春百度关键词优化
  • 网盘 商业网站建设案例课程 下载站长工具 站长之家
  • 网站测试工具如何在百度提交自己的网站
  • 电商网站建设功能网络营销文案策划
  • 安阳网站建设优化渠道软文代写网
  • 佛山新网站制作公司宁波网站关键词排名推广
  • 网站制作 郑州市场调研流程
  • 网站设计就业前景如何站长工具的使用seo综合查询运营