数据库:怎么判断关系是第几范式~看一遍就懂了~
Posted 偷书的程序猿
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据库:怎么判断关系是第几范式~看一遍就懂了~相关的知识,希望对你有一定的参考价值。
数据库:怎么判断关系是第几范式
相关知识点这里,希望能给大家带来帮助!!!
下面不必浏览
什么是”范式(NF)”
按照教材中的定义,范式是“符合某一种级别的关系模式的集合,表示一个关系内部各属性之间的联系的合理化程度”。很晦涩吧?实际上你可以把它粗略地理解为一张数据表的表结构所符合的某种设计标准的级别。就像家里装修买建材,最环保的是E0级,其次是E1级,还有E2级等等。数据库范式也分为1NF,2NF,3NF,BCNF,4NF,5NF。一般在我们设计关系型数据库的时候,最多考虑到BCNF就够。符合高一级范式的设计,必定符合低一级范式,例如符合2NF的关系模式,必定符合1NF。
2.1 函数依赖
我们可以这么理解(但并不是特别严格的定义):若在一张表中,在属性(或属性组)X的值确定的情况下,必定能确定属性Y的值,那么就可以说Y函数依赖于X,写作 X → Y。也就是说,在数据表中,不存在任意两条记录,它们在X属性(或属性组)上的值相同,而在Y属性上的值不同。这也就是“函数依赖”名字的由来,类似于函数关系 y = f(x),在x的值确定的情况下,y的值一定是确定的。
例如,对于表3中的数据,找不到任何一条记录,它们的学号相同而对应的姓名不同。所以我们可以说姓名函数依赖于学号,写作 学号 → 姓名。但是反过来,因为可能出现同名的学生,所以有可能不同的两条学生记录,它们在姓名上的值相同,但对应的学号不同,所以我们不能说学号函数依赖于姓名。表中其他的函数依赖关系还有如:
系名 → 系主任学号 → 系主任
(学号,课名) → 分数
但以下函数依赖关系则不成立:
学号 → 课名
学号 → 分数
课名 → 系主任
(学号,课名) → 姓名
从“函数依赖”这个概念展开,还会有三个概念:
2.1.1完全函数依赖
在一张表中,若 X → Y,且对于 X 的任何一个真子集(假如属性组 X 包含超过一个属性的话),X ’ → Y 不成立,那么我们称 Y 对于 X 完全函数依赖,记作 X F→ Y。(那个F应该写在箭头的正上方,没办法打出来……,正确的写法如图1)
图1
例如: 学号 F→ 姓名 (学号,课名) F→ 分数 (注:因为同一个的学号对应的分数不确定,同一个课名对应的分数也不确定)
2.1.2 部分函数依赖
假如 Y 函数依赖于 X,但同时 Y 并不完全函数依赖于 X,那么我们就称 Y 部分函数依赖于 X,记作 X P→ Y,如图2。
图2
例如:(学号,课名) P→ 姓名 传递函数依赖假如 Z 函数依赖于 Y,且 Y 函数依赖于 X (感谢 @百达 指出的错误,这里改为:『Y 不包含于 X,且 X 不函数依赖于 Y』这个前提),那么我们就称 Z 传递函数依赖于 X ,记作 X T→ Z,如图3。
图3
2.2 码
设 K 为某表中的一个属性或属性组,若除 K 之外的所有属性都完全函数依赖于 K(这个“完全”不要漏了),那么我们称 K 为候选码,简称为码。在实际中我们通常可以理解为:假如当 K 确定的情况下,该表除 K 之外的所有属性的值也就随之确定,那么 K 就是码。一张表中可以有超过一个码。(实际应用中为了方便,通常选择其中的一个码作为主码) 例如:对于表3,(学号、课名)这个属性组就是码。该表中有且仅有这一个码。(假设所有课没有重名的情况)
2.3 非主属性
包含在任何一个码中的属性成为主属性
Mybatis 全局配置文件详解
这节来说说全局配置文件的东西,非常简单。看一遍就懂了。
--WH
一、全部配置内容
SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱。现在来对这些属性的意思一一进行讲解。
二、properties
作用:引用java属性文件中的配置信息,比如,加载连接数据库的各种属性的配置文件。
db.properties
1 <!-- 2 properties:引用java属性文件中的配置信息 3 比如加载连接数据库的帐号密码等信息的properties配置文件。 4 使用${}可以引用已经加载的java配置文件中的信息 5 使用时注意一个问题,mybatis按照下面的顺序加载属性 6 1、properties标签体内的属性 7 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value), 8 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖 9 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值 10 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。 11 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖 12 --> 13 <properties resource="db.properties"> 14 <!-- 这里就是properties标签体内的属性 15 比如: <property name="" value=""/> 16 --> 17 </properties> 18 //使用db.properties中的配置信息 19 <dataSource type="POOLED"> 20 <!-- 引用db.properties中的信息,通过${} --> 21 <property name="driver" value="${db.driver}"/> 22 <property name="url" value="${db.url}"/> 23 <property name="username" value="${db.username}"/> 24 <property name="password" value="${db.password}"/> 25 </dataSource>
三、settings
<!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
这个在后面讲解懒加载时会讲解到。比如设置懒加载的全局参数
1 <!-- setting 全局参数,比如懒加载、是否启动缓存机制--> 2 <settings> 3 <!-- 打开延迟加载的开关,默认为true --> 4 <setting name="lazyLoadingEnabled" value="true"/> 5 <!-- 积极的懒加载,默认是true,设置为false时,懒加载生效 --> 6 <setting name="aggressiveLazyLoading" value="false"/> 7 </settings> 8
四、typeAliases
别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,就是在这里设置。(使用推荐的)
1 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int, 2 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是 3 我们也可以自定义别名, 4 com.wuhao.mybatis.domain.User 使用别名 user 代替 5 --> 6 <typeAliases> 7 <!-- 单个定义别名 --> 8 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/> 9 <!-- 批量定义别名(推荐) 10 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以) 11 --> 12 <!-- <package name="com.wuhao.mybatis.domain"/> --> 13 </typeAliases>
mybatis中有很多默认的别名,也就是帮我们写好了的,比如八大基本类型,
五、typeHandlers
类型转换器,将数据库的类型转换成java的类型,mybatis会帮我们做这个事情,我们不需要自己设置,在mybatis的jar包中,有一个
其中就会将类型转换器,转换哪些java类型都会列举出来,我们去看看,用来借鉴借鉴,等用到了可以到里面查查,
六、objectFactory
对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理,到与spring整合的时候就会讲解到对象工厂的了。
七、mappers
加载映射文件,也就是我们配置的映射文件,在这里需要显示声明加载。有四种方式加载,使用推荐的那种,其他的了解
使用第四种方式加载
1 <!-- 2 mappers:加载映射文件 3 四种方式来加载 4 1、<mapper resource="config/sqlmap/user.xml"/> 5 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml 6 2、<mapper url=’’/> 7 使用绝对路径,比如d盘下的xx,不会用这种 8 3、<mapper class=’’/> 9 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件 10 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下, 11 比如:UserMapper.java(接口) UserMapper.xml(映射文件) 12 4、<package name=’’/>(推荐) 13 注册指定包下的所有映射文件 14 <package name="com.wuhao.mapper"/> 15 配置了com.wuhao.mapper下的所有映射文件, 16 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下 17 --> 18 <mappers> 19 <!-- <mapper resource="sqlmap/User.xml"/> --> 20 <!-- 批量加载映射文件 --> 21 <package name="com.wuhao.mapper"/> 22 <package name="com.wuhao.shuru"/> 23 <package name="com.wuhao.resultMap"/> 24 <package name="com.wuhao.onetoone"/> 25 </mappers>
八,总的配置文件代码
1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE configuration 3 PUBLIC "-//mybatis.org//DTD Config 3.0//EN" 4 "http://mybatis.org/dtd/mybatis-3-config.dtd"> 5 <configuration> 6 <!-- 7 属性 8 <properties></properties> 9 全局参数设置 10 <settings></settings> 11 类型别名 12 <typeAliases></typeAliases> 13 类型处理器 14 <typeHandles></typeHandles> 15 对象工厂 16 <objectFactory></objectFactory> 17 插件 18 <plugins></plugins> 19 以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可 20 如下所配置的就是使用这点东西。 21 environments(环境信息集合) 22 environment(单个环境信息) 23 transactionManager(事物) 24 dataSource(数据源) 25 environment 26 environments 27 mappers(映射器) 28 --> 29 30 <!-- 31 properties:引用java属性文件中的配置信息 32 比如加载连接数据库的帐号密码等信息的properties配置文件。 33 使用${}可以引用已经加载的java配置文件中的信息 34 使用时注意一个问题,mybatis按照下面的顺序加载属性 35 1、properties标签体内的属性 36 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value), 37 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖 38 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值 39 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。 40 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖 41 --> 42 <properties resource="db.properties"> 43 <!-- 这里就是properties标签体内的属性 44 比如: <property name="" value=""/> 45 --> 46 </properties> 47 48 <!-- setting 全局参数,比如懒加载、是否启动缓存机制--> 49 <!-- <settings> 50 打开延迟加载的开关,默认为true 51 <setting name="lazyLoadingEnabled" value="true"/> 52 积极的懒加载,默认是true,设置为false时,懒加载生效 53 <setting name="aggressiveLazyLoading" value="false"/> 54 </settings> --> 55 56 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int, 57 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是 58 我们也可以自定义别名, 59 com.wuhao.mybatis.domain.User 使用别名 user 代替 60 --> 61 <typeAliases> 62 <!-- 单个定义别名 --> 63 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/> 64 <!-- 批量定义别名(推荐) 65 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以) 66 --> 67 <!-- <package name="com.wuhao.mybatis.domain"/> --> 68 </typeAliases> 69 70 <!-- 类型转换器,将数据库的类型转换成java的类型, 71 mybatis会帮我们做这个事情,我们不需要自己设置, 72 <typeHandlers></typeHandlers> 73 --> 74 75 <!-- 76 对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。 77 <objectFactory></objectFactory> 78 --> 79 80 <!-- 81 mappers:加载映射文件 82 四种方式来加载 83 1、<mapper resource="config/sqlmap/user.xml"/> 84 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml 85 2、<mapper url=’’/> 86 使用绝对路径,比如d盘下的xx,不会用这种 87 3、<mapper class=’’/> 88 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件 89 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下, 90 比如:UserMapper.java(接口) UserMapper.xml(映射文件) 91 4、<package name=’’/>(推荐) 92 注册指定包下的所有映射文件 93 <package name="com.wuhao.mapper"/> 94 配置了com.wuhao.mapper下的所有映射文件, 95 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下 96 --> 97 98 99 100 <!-- 配置mybatis的环境信息 --> 101 <environments default="development"> 102 <environment id="development"> 103 <!-- 配置JDBC事务控制,由mybatis进行管理 --> 104 <transactionManager type="JDBC"></transactionManager> 105 <!-- 配置数据源,采用dbcp连接池 --> 106 <dataSource type="POOLED"> 107 <!-- 引用db.properties中的信息,通过${} --> 108 <property name="driver" value="${db.driver}"/> 109 <property name="url" value="${db.url}"/> 110 <property name="username" value="${db.username}"/> 111 <property name="password" value="${db.password}"/> 112 </dataSource> 113 </environment> 114 </environments> 115 <!-- 加载mapper映射文件 --> 116 <mappers> 117 <!-- <mapper resource="sqlmap/User.xml"/> --> 118 <!-- 批量加载映射文件 --> 119 <package name="com.wuhao.mapper"/> 120 <package name="com.wuhao.shuru"/> 121 <package name="com.wuhao.resultMap"/> 122 <package name="com.wuhao.onetoone"/> 123 </mappers> 124 </configuration>
九、总结
以上就把全局配置文件中的内容全部给讲解了一遍,其中
没有具体讲解这个,因为都是死东西,在前一章节都是使用这个,所以就不在过多分析,其他的都有讲解到是什么作用,现在应该对前面一章的东西有更加深入的理解,但是需要彻底理解,还需要等待下一章讲解映射文件之后才能够更加清晰。加油。
以上是关于数据库:怎么判断关系是第几范式~看一遍就懂了~的主要内容,如果未能解决你的问题,请参考以下文章
数据库中,三种范式之间的区别,如何判断某个关系属于第几范式?