MYSQL数据库建表注意事项

Posted 虚极静笃

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQL数据库建表注意事项相关的知识,希望对你有一定的参考价值。

1.库名、表名、字段名必须使用小写字母,“_”分割。

原因:

mysql在Linux下数据库名、表名、列名、别名大小写规则是这样的:
  1、数据库名表名是严格区分大小写的;
  2、表的别名是严格区分大小写的;
  3、列名与列的别名在所有的情况下均是忽略大小写的;
  4、变量名也是严格区分大小写的;
MySQL在Windows下都不区分大小写。
  所以在不同操作系统中为了能使程序和数据库都能正常运行,最好的办法是在设计的时候都转为小写,但是如果在设计的时候已经规范化大小写了,那么在Windows环境下只要对数据库的配置做下改动就行了,具体操作如下:
  在MySQL的配置文件中my.ini [mysqld]中增加一行 lower_case_table_names = 1
  参数解释:
  0:区分大小写
  1:不区分大小写
在 MySQL中,数据库和表对就于那些目录下的目录和文件。因而,操作系统的敏感性决定数据库和表命名的大小写敏感。这就意味着数据库和表名在Windows 中是大小写不敏感的,而在大多数类型的 Unix系统中是大小写敏感的。奇怪的是列名与列的别名在所有的情况下均是忽略大小写的,而表的别名又是区分大小写的。
要避免这个问题,你最好在定义数据库命名规则的时候就全部采用小写字母加下划线的组合,而不使用任何的大写字母。
或者也可以强制以 -O lower_case_table_names=1 参数启动mysqld(如果使用 --defaults-file=...\\my.cnf参数来读取指定的配置文件启动 mysqld的话,你需要在配置文件的 [mysqld] 区段下增加一行lower_case_table_names=1)。这样MySQL
将在创建与查找时将所有的表名自动转换为小写字符(这个选项缺省地在Windows 中为 1 ,在 Unix 中为 0。从 MySQL 4.0.2开始,这个选项同样适用于数据库名)。

2.建议使用InnoDB存储引擎(如果一个表极少更新可以考虑MyISAM)。

原因:

 

1.MyISAM

    MyISAM是mysql5.1及之前版本的默认引擎,很久未被更新。

    使用表级锁, 如果数据量大,一个插入操作锁定表后,其他请求都将阻塞。

    支持全文索引

    支持查询缓存

保存表的总行数,使用count(*) 并且无where子句的时候可以很快返回结果,但是实际使用时基本不会无where子句

简要:不支持事务安全 

没有事务日志和分类,因此它只将数据写入Linux文件缓存并希望能最终写入磁盘。如果系统在这个过程中崩溃或者丢失一些数据,MyISAM表会经常出现无法启动或者警告你需要修复表;它恢复数据的方法有限并且经常会丢失数据。另外,MyISAM也很难正确的备份,备份的时候通常需要锁住整个系统的数据,这就意味着每天网站都要宕机或者无法使用一段时间。

 

MyISAM表允许在定期列中进行全文检索,而InnoDB不支持(这个没搞懂)

2.InnoDB

    支持事务

    支持行级锁和表级锁,能支持更多的并发量

    mysql5.6版本开始支持 全文索引

    查询不加锁,完全不影响查询

    Innodb会对每个表设置一个事务计数器,里面存储当前最大的事务ID.当一个事务提交时,InnoDB会使用MVCC中系统事务ID最大的事务ID跟新当前表的计数器.只有比这个最大ID大的事务能使用查询缓存,其他比这个ID小的事务则不能使用查询缓存.另外,在InnoDB中,所有有加锁操作的事务都不使用任何查询缓存

简要:支持事务安全   

事务日志记录真正的数据库事务,但更重要的是数据崩溃恢复和回滚。基于 InooDB方式的IO,能给予更安全数据保护和更好性能表现


作者:河边的老牛
链接:http://www.jianshu.com/p/6b45b150bfbf
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
 
3.存储精确浮点数必须使用DECIMAL替代FLOAT和DOUBLE。
 

4.建议使用UNSIGNED存储非负数值。

 
5.建议使用INT UNSIGNED存储IPV4。
原因:
使用INTUNSIGNED而不是char(15)来存储ipv4地址,通过MySQL函数inet_ntoa和inet_aton来进行转化;Ipv6地址目前没有转化函数,需要使用DECIMAL或者两个bigINT来存储。例如:

create table t (

ip INT UNSIGNED

);
insert into t select INET_ATON(\'209.207.224.40\');
select INET_NTOA(ip) from t;

 

6.整形定义中不添加长度,比如使用INT,而不是INT(4)。

长度与你存放的数值型的数的大小无关(参考http://www.cnblogs.com/echo-something/archive/2012/08/26/mysql_int.html

 

以上是关于MYSQL数据库建表注意事项的主要内容,如果未能解决你的问题,请参考以下文章

mysql workbench 导出建表语句

记录Mysql 建表注意事项

获取MySQL中某个数据库下所有表建表语句的DDL

Mysql的建表规范与注意事项

oracle建表语句

初触hibernate01--MYSQL建表时type=InnoDB和Engine=InnoDB注意点