MySQL--零碎知识

文章目录

  • MySQL--零碎知识
    • 数据库范式
    • 数据库类型
      • 1.关系数据库(SQL)
      • 2.非关系型数据库(NoSQL)
    • 奇怪的NULL

MySQL–零碎知识

数据库范式

第一范式

一范式就是属性不可分割。属性是什么?就是表中的字段。
不可分割的意思就按字面理解就是最小单位,不能再分成更小单位了。
这个字段只能是一个值,不能被拆分成多个字段,否则的话,它就是可分割的,就不符合一范式。
不过能不能分割并没有绝对的答案,看需求,也就是看你的设计目标而定。
举例:
学生信息组成学生信息表,有姓名、年龄、性别、学号等信息组成。
姓名不可拆分吧?所以可以作为该表的一个字段。
但我要说这个表要在国外使用呢?人家姓和名要分开,都有特别的意义,所以姓名字段是可拆分的,分为姓字段和名字段。

第二范式

二范式就是要有主键,要求其他字段都依赖于全部主键。
为什么要有主键?没有主键就没有唯一性,没有唯一性在集合中就定位不到这行记录,所以要主键。
其他字段为什么要依赖于主键?因为不依赖于主键,就找不到他们。更重要的是,其他字段组成的这行记录和主键表示的是同一个东西,而主键是唯一的,它们只需要依赖于主键,也就成了唯一的。
如果有同学不理解依赖这个词,可以勉强用“相关”这个词代替,也就是说其他字段必须和它们的主键相关。因为不相关的东西不应该放在一行记录里。
举例:
学生信息组成学生表,姓名可以做主键么?
不能!因为同名的话,就不唯一了,所以需要学号这样的唯一编码才行。
那么其他字段依赖于主键是什么意思?

第三范式

三范式就是要消除传递依赖,方便理解,可以看做是“消除冗余”。
消除冗余应该比较好理解一些,就是各种信息只在一个地方存储,不出现在多张表中。
比如说大学分了很多系(中文系、英语系、计算机系……),这个系别管理表信息有以下字段组成:
系编号,系主任,系简介,系架构。
那么再回到学生信息表,张三同学的年龄、性别、学号都有了,我能不能把他的系编号,系主任、系简介也一起存着?
如果你问三范式,当然不行,因为三范式不同意。
因为系编号,系主任、系简介已经存在系别管理表中,你再存入学生信息表,就是冗余了。
三范式中说的传递依赖,就出现了。
这个时候学生信息表中,系主任信息是不是依赖于系编号了?而这个表的主键可是学号啊!
所以按照三范式,处理这个问题的时候,学生表就只能增加一个系编号字段。

数据库类型

1.关系数据库(SQL)

  • MySQL
    • MariaDB(MySQL的代替品,英文维基百科从MySQL转向MariaDB)
    • [Percona Server](https://baike.baidu.com/item/Percona Server)(MySQL的代替品·)
  • PostgreSQL
  • [Microsoft Access](https://baike.baidu.com/item/Microsoft Access)
  • [Microsoft SQL Server](https://baike.baidu.com/item/Microsoft SQL Server)
  • Google Fusion Tables
  • FileMaker
  • Oracle数据库
  • DB2
  • Sybase
  • dBASE
  • Clipper
  • FoxPro

2.非关系型数据库(NoSQL)

主条目:NoSQL

  • BigTable(Google)
  • Cassandra
  • MongoDB
  • CouchDB

键值(key-value)数据库

  • [Apache Cassandra](https://baike.baidu.com/item/Apache Cassandra)(为Facebook所使用):高度可扩展
  • Dynamo
  • LevelDB(Google)
  • Kafka
  • Redis

奇怪的NULL

null是空类型,比较时只能用is nullis not null,其他都返回为null

效率不高,影响提高索引结果

所以我们在建表时not null default 0


mysql> create table name(
    -> sname varchar(20)
    -> )engine myisam charset utf8;
Query OK, 0 rows affected, 1 warning (1.40 sec)

mysql> insert into name values ('zhangsan'),('lisi'),('wangwu'),(NULL);
Query OK, 4 rows affected (0.46 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql> select * from name;
+----------+
| sname    |
+----------+
| zhangsan |
| lisi     |
| wangwu   |
| NULL     |
+----------+
4 rows in set (0.01 sec)

mysql> #查询出用户名不为null的用户
mysql> select * from name where sname!=null;
Empty set (0.03 sec)

mysql> select * from name where sname!=NULL;
Empty set (0.00 sec)

mysql> #查询出用户名为null的用户
mysql> select * from name where sname=NULL;
Empty set (0.01 sec)

mysql> select 2>1
    -> ;
+-----+
| 2>1 |
+-----+
|   1 |
+-----+
1 row in set (0.00 sec)

mysql> select 'lisi'=null;
+-------------+
| 'lisi'=null |
+-------------+
|        NULL |
+-------------+
1 row in set (0.00 sec)

mysql> select null=null;
+-----------+
| null=null |
+-----------+
|      NULL |
+-----------+
1 row in set (0.00 sec)

mysql> select null!=null;
+------------+
| null!=null |
+------------+
|       NULL |
+------------+
1 row in set (0.00 sec)

mysql> #null是空
mysql> #null比较需要用特殊运算符比较
mysql> select * from name where sname is not null;
+----------+
| sname    |
+----------+
| zhangsan |
| lisi     |
| wangwu   |
+----------+
3 rows in set (0.00 sec)

mysql> select * from name where sname is null;
+-------+
| sname |
+-------+
| NULL  |
+-------+
1 row in set (0.00 sec)

你可能感兴趣的:(SQL学习)