今天给大家介绍一下数据库设计过程中字段的选择原则,也就是什么时候用int、什么时候用varchar、什么时候用char等等之类的。...如果想要全面的了解的话,大家可以去看高性能MYSQL这一本书籍,里面有一章节介绍的特别全面,基本涉及MYSQL中全部的字段的介绍。...在数据库设计过程中我们要本着够用的原则,如果一味的把数据字段范围设为最大或者默认值的话,会导致存储空间大量的浪费。...在数据量特别大的情况下,这样的设计原理将会使数据库空间造成严重的浪费,也会对数据库的执行效率造成很大的影响。所以我们在做数据库设计的时候要谨慎再谨慎、小心再小心。...2.数据库设计过程中尽量使用int来作为字段类型,因为在所有的数据类型中int不管是存储空间还是执行速度方面都是最好的。
前言: 要了解一个数据库,我们必须了解其支持的数据类型。MySQL 支持大量的字段类型,其中常用的也有很多。...浮点型主要有 float,double 两个,浮点型在数据库中存放的是近似值,例如float(6,3),如果插入一个数123.45678,实际数据库里存的是123.457,但总个数还以实际为准,即6位,...定点型字段类型有 DECIMAL 一个,主要用于存储有精度要求的小数。 DECIMAL 从 MySQL 5.1 引入,列的声明语法是 DECIMAL(M,D) 。...3.日期时间类型 MySQL支持的日期和时间类型有 YEAR 、TIME 、DATE 、DATETIME 、TIMESTAMP,几种类型比较如下: 涉及到日期和时间字段类型选择时,根据存储需求选择合适的类型即可...总结: 本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
Mysql是以文件存储在我们的系统的硬盘上面,那么 (1)当我们读取写入的时候就会有磁盘IO的问题 (2)当我们存储的数据是以页单位存储,而且每页的大小是16K,那么我们要尽可能的让我们的一页数据存放的更多...表结构宽度不要太大,也就是列数不要过多,保存更可能多的行数,那么针对行数存储就会涉及到字段类型选择的问题 以下字节按照utf8来示例,一个中文占3个字节,一个数字和字母是一个字节,而且utf8是变长的
在使用thinkphp的时候,我遇到过数据库字段名大小写的问题,使用M()方法的时候,thinkphp默认会寻找小写的数据库字段,通过以下方法解决了: 就是修改thinkphp的源码中的Library/...preg_replace_callback('/_([a-zA-Z])/', function(match){return strtoupper(match[1]);}, name)); } else { //这里会将数据库表名里的大写转换为...里面的getTableName函数: //this->trueTableName = strtolower(this->trueTableName = 修改其中一句,这样就可以解决数据库字段名大写的问题
Oracle/MSSQL/Mysql 常用数据库的字段类型及大小 ORACLE的数据类型 常用的数据库字段类型如下: 字段类型 中文说明 限制条件 其它说明 CHAR 固定长度字符串...其存储窨的大小是 n + 4 个字节。 Varbinary[(n)] 是 n 位变长度的二进制数据。其中,n 的取值范围是从 1 到 8000。...使用Unicode数据类型,所战胜的窨是使用非 Unicode 数据类型所占用的窨大小的两倍。 ...SQL SERVER的字段类型说明 以下为SQL SERVER7.0以上版本的字段类型说明。SQL SERVER6.5的字段类型说明请参考SQL SERVER提供的说明。...SYBASE的字段类型如下: 字段类型描述字段长度及其缺省值 Char(Size) 用于保存定长(Size)字节的字符串数据。
数据定义语言:字段约束 数据库的范式 构造数据库必须遵循一定的规则,这种规则就是范式 目前关系数据库有 6 种范式,一般情况下,只满足第三范式即可 第一范式:原子性 第一范式是数据库的基本要求,不满足这一点就不是关系数据库...为了实现区分,通常要为表上加一个列用来存储唯一标识,这个唯一属性列被称作主键列 第三范式:关联性 每列都与主键有直接关系,不存在传递依赖 依照第三范式,数据可以拆分保存到不同的数据表,依次保持关联 字段约束...MySQL 中的字段约束共有四种: 约束名称 关键字 描述 主键约束 PRIMARY KEY 字段值唯一,且不能为 NULL 非空约束 NOT NULL 字段值不能为 NULL 唯一约束 UNIQUE...字段值唯一,且可以为 NULL 外键约束 FOREIGN KEY 保持关联数据的逻辑性 外键约束是唯一不推荐使用的约束 主键约束 主键约束要求字段的值在全表必须唯一,而且不能为 NULL 值 建议主键一定要使用数据类型...如果主键是数字类型,还可以设置自动增长 CREATE TABLE t_teacher( id INT PRIMARY KEY AUTO_INCREMENT, ... ... ); 非空约束 非空约束要求字段的值不能为
要想知道每个数据库的大小的话,步骤如下: 1、进入information_schema 数据库(存放了其他的数据库的信息) use information_schema; 2、查询所有数据的大小: select...concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables; 3、查看指定数据库的大小: 比如查看数据库home的大小 select...concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables where table_schema=‘home’; 4、查看指定数据库的某个表的大小...比如查看数据库home中 members 表的大小 select concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables
在thinkphp查询后台数据库时候,当我们的数据库字段命名中含有大写字母时,默认框架会将大写的字段名全部转换为小写,就很有可能导致我们在对查询数据进行处理的时候出现变量获取值为NULL或空的情况 解决方法
记录一下,根据工作中项目交付要求,要将MySQL数据库中的表名和字段名中做一个规范,其中就有将表名和字段名统一做小写处理。...废话不多说,直接上MySQL脚本: 批量修改数据库下的表名(大写改小写): SELECT concat( 'rename table ' , TABLE_NAME , ' to ' , LOWER...(TABLE_NAME) ,' ;' ) AS '修改脚本sql' FROM information_schema.TABLES t WHERE TABLE_SCHEMA = '数据库名'; 批量修改列名...COLUMN_DEFAULT ), '\'' )), ';' ) AS '修改脚本sql' FROM information_schema.COLUMNS t WHERE TABLE_SCHEMA = '数据库名
之前在百度上面查询到修改字段的语句: alert table 表名 alter column 列名 类型【大小】null or not null; 但是执行完这句话后发现报错 后来修改一下语句...alter table 表名 modify ( 列名 类型【大小】); ok,编译通过。
【Oracle 数据库的操作】 之前在百度上面查询到修改字段的语句: alert table 表名 alter column 列名 类型【大小】null or not null; 但是执行完这句话后发现报错...后来修改一下语句 alter table 表名 modify ( 列名 类型【大小】); 例如: alter table sutudent modify(s_phone varchar(128
今天asong教你们一个mysql优化设计状态标识。...这时我们思考一个问题,数据库是怎么存储这些优惠的呢?...根据上面的举例,用户下单时可以同时使用上面4种优惠抵扣方式,也就说用户可能出现的组合有2^4 - 1=15种,如果我们的表结构设计成单独用一个普通标识字段来标识存储,实现起来是比较简单,但是其需要标识的组合种类实在有点多...在互联网场景下,数据量通常是非常大的,像订单数据一般都需要进行数据库sharding,以应对数据量暴涨后数据库的读写性能瓶颈,增加系统的水平扩展能力。...要知道,在互联网场景下,业务的变化是非常快的,新加字段并不是那么方便。 方便标识存储,一个字段就可以标识多种业务场景。
MySQL数据库占用的空间、表记录的行数在MySQL的 information_schema 数据库。...在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA -- 数据库名 TABLE_NAME -- 表名 ENGINE -- 所使用的存储引擎 TABLES_ROWS --...记录数 DATA_LENGTH -- 数据大小 INDEX_LENGTH -- 索引大小 查询方法 查询某个数据库的空间大小 SELECT concat(round(sum(DATA_LENGTH/1024.../1024),2),'MB') as data FROM TABLES WHERE table_schema='要查询的数据库名字'; 查询某个数据库中某个表的空间大小 SELECT concat(round...(sum(DATA_LENGTH/1024/1024),2),'MB') as data FROM TABLES WHERE table_schema='要查询的数据库名字' and TABLE_NAME
SQL语句查看MySQL数据库大小 > SELECT table_schema "Database Name", sum( data_length + index_length ) / 1024 / 1024...0.09472656 | | information_schema | 0.15625000 | | jumpserver | 1.46875000 | | mysql...表大小 例子:查看hellodb数据库,只显示出zabbix库中最大的10个表 > SELECT table_name AS "Tables",round(((data_length + index_length... | 0.02 | | t2 | 0.00 | +----------+------------+ 7 rows in set (0.00 sec) 找出前10的表大小.../mysql-howto-find-the-database-and-table-size/
mysql设计字段的原则总结 1、尽量使用整型表示字符串。...非null字段的处理比null字段的处理更有效率!无需判断是否为null。 5、字段注释要完整。 6、单表字段不宜过多。 二三十个就了。 7、可以预留字段。 在使用以上原则之前首先要满足业务需求。...以上就是mysql设计字段的原则总结,希望对大家有所帮助。更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑
引言 在数据库设计领域,Null(空值)与非空(NOT NULL)字段的合理应用对于构建高效、稳定且易于维护的数据库系统至关重要。...本文将深入探讨MySQL数据库中的Null与非空字段概念,分析它们各自的特点、使用场景及设计建议,以帮助软件架构师和系统架构师更好地理解和应用这些概念。...Null与非空字段概念 Null字段 定义:Null在数据库中代表一个字段的“未知”或“不存在”状态。 特点: Null不等同于0、空字符串或任何其他默认值。...设计建议 明确需求:在设计表结构时,首先明确每个字段是否为业务逻辑中的必要元素。 合理使用Null:不应滥用Null,因为它会增加查询逻辑的复杂性,并可能导致意外的结果。...测试与验证:在实际应用中,应进行充分的测试,以确保Null和非空字段的逻辑符合业务预期。 结论 正确地应用Null与非空字段是MySQL数据库表设计的重要方面。
mysql里面有个坑就是,有时按照某个字段的大小排序(或是比大小)发现排序有点错乱。后来才发现,是我们想当然地把对字符串字段当成数字并按照其大小排序(或是比大小),结果肯定不会是你想要的结果。...最简单的办法就是在字段后面加上+0 如把’123’转成数字123(以下例子全为亲测): 排序: 例: 方法一:ORDER BY ‘123’+0;(首推) 方法二:ORDER BY CAST(‘123’...AS SIGNED); 方法三:ORDER BY CONVERT(‘123’,SIGNED); 比大小: 例: SELECT ‘123’+0; — 结果为123 SELECT ‘123’+0>127
字段设计规范 1....而且对于这种数据,MySQL 还是要进行二次查询,会使 sql 性能变得很差,但不是说一定不能使用这样的数据类型。...TEXT 或 BLOB 类型只能使用前缀索引 因为 MySQL[1] 对索引字段长度是有限制的,所以 TEXT 类型只能使用前缀索引,并且 TEXT 列上是不能有默认值的 3....decimal Decimal 类型为精准浮点数,在计算时不会丢失精度;占用空间由定义的宽度决定,每 4 个字节可以存储 9 位数字,并且小数点要占用一个字节;可用于存储比 bigint 更大的整型数据 索引设计规范...因为 MySQL 优化器在选择如何优化查询时,会根据统一信息,对每一个可以用到的索引来进行评估,以生成出一个最好的执行计划,如果同时有很多个索引都可以用于查询,就会增加 MySQL 优化器生成执行计划的时间
查看一个数据中所有表的相关信息: (1)可以在命令下使用show table status \G命令查看: (2)如果想知道MySQL数据库中每个表占用的空间、表记录的行数的话,可以打开MySQL的 information_schema...在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA : 数据库名 TABLE_NAME:表名 ENGINE:所使用的存储引擎 TABLES_ROWS:记录数 DATA_LENGTH...:数据大小 INDEX_LENGTH:索引大小 其他字段请参考MySQL的手册,我们只需要了解这几个就足够了。...例:查看mysql库容量大小 select table_schema as '数据库', sum(table_rows) as '记录数', sum(truncate(data_length/1024...'; 4.查看指定数据库各表容量大小 例:查看mysql库各表容量大小 select table_schema as '数据库', table_name as '表名', table_rows as
领取专属 10元无门槛券
手把手带您无忧上云