(摘)
逻辑独立性外模式不变模式改变时,如增加新的关系,新的属性,改变属性的数据类型,由数据库管理员对各个外模式/模式的映像做相应改变,可以使得外模式不变,因为应用程序依据外模式编写的所以外模式不变,应用程序也不变,即保证了逻辑独立

物理独立性是模式不变内模式改变,如数据库存储结构发生改变,选用另一种数据结构,由数据库管理员对各个模式/内模式的映像做相应改变,可以使得模式不变 ,从而保证了应用程序也不变

从下往上控制改变


  • 聚集函数里只有SUM AVG需要参数是数值型
  • 聚合函数MAX(<列名>)用于求某一列值的最大值,它对列名不限制数据类型。

外模式也称子模式,通常是模式的子集。-----《数据库系统概论》


删除异常: 不该删除的但是却被删除;
插入异常:应该插入的但是却没有被插入;


  • All():对所有数据都满足条件,整个条件才成立,>=all()等价于max,<=all()等价于min;
  • Any:只要有一条数据满足条件,整个条件成立,>any()等价于>min,<any()等价于<max;
    some的作用和Any一样

在数据库技术中,为提高数据库的逻辑独立性和物理独立性,数据库的结构被划分成用户级、概念级,和存储级三个层次。


  • DFD图即为数据流图(Data Flow Diagram),它从数据传递和加工角度,以图形方式来表达系统的逻辑功能、数据在系统内部的逻辑流向和逻辑变换过程,是结构化系统分析方法的主要表达工具及用于表示软件模型的一种图示方法。
  • E-R是实体联系图 里面有方形圆形和菱形
  • I/O图是输入输出图
  • IPO图是输入加工输出图

SQL server支持的备份类型有四种:
1、完全数据库备份
2、差异备份或称增量备份
3、事务日志备份
4、数据库文件和文件组备份


MySql中的权限分为五个级别:

Global Level:Global Level所有权限信息都保存在mysql.user 表中,它的所有权限都是针对整个mysqld 的,对所有的数据库下的所有表及所有字段都有效

Database Level:Database Level其作用域即为所指定整个数据库中的所有对象

Table Level:Table Level 的权限作用范围是授权语句中所指定数据库的指定表。Table Level 的权限由于其作用域仅限于某个特定的表,所以权限种类也比较少,仅有
ALTER,CREATE,DELETE,DROP,INDEX,INSERT,SELECT UPDATE 这八种权限。

Column Level:Column Level 的权限作用范围就更小了,仅仅是某个表的指定的某个(活某些)列。Column Level 级别的权限仅有 INSERT , SELECT 和 UPDATE 这三种。

Routine Level:Routine Level 的权限主要只有EXECUTE 和ALTER ROUTINE 两种,主要针对的对象是procedure 和function 这两种对象。


Mysql sql注入中使用延时注入时常用的语句是:sleep(5);


数据库的外键可以为空也可以非空,但是如果非空,则这个值必须在主表中存在


视图设计一般有 3 种设计次序,
通常有如下几种方法:
1、自顶向下。先全局框架,然后逐步细化
2、自底向上。先局部概念结构,再集成为全局结构
3、由里向外。先核心结构,再向外扩张
4、混合策略。1与2相结合,先自顶向下设计一个概念结构的框架,再自底向上为框架设计局部概念结构


SQL Server中每一条select、insert、update、delete语句都是隐形事务的一部分,显性事务用BEGIN TRANSACTION明确指定事务。


数据库主要(根本)解决的是数据的共享问题
DBMS中实现事务持久性
的子系统是恢复管理子系统


这是关于查询树的启发式优化规则的代数优化,对关系代数表达式的查询树进行优化,典型的启发式规则有

  1. 选择运算尽可能早做,在优化策略中这是最重要,最基本的一条,它常常可以使执行节约几个数量级,因为选择运算一般使计算的中间结果大大变小
  2. 投影运算和选择运算同时进行。如果有若干的投影和选择运算,并且他们都对同一个关系进行操纵的话,就可以在扫描此关系的同时完成所有的这些运算以避免重复扫描关系。
  3. 投影同其前或其后的双目运算结合起来,没有必要为了去掉某些字段而扫描一遍关系
  4. 把某些选择同在他前面要执行的笛卡儿积结合成一个连接运算,连接特别是等值连接运算要比同样关系上的笛卡儿积省很多时间
  5. 找出公共子表达式
    (数据库优化是一个重点)

(摘)
数据字典是数据库的重要组成部分。它存放有数据库所有的有关信息,对用户来说是一组只读的表。数据字典内容包括:
1、数据库中所有模式对象的信息,如表、视图、簇、及索引等。
2、分配多少空间,当前使用了多少空间等。
3、列的缺省值。
4、约束信息的完整性。
5、用户的名字。
6、用户及角色被授予的权限。
7、用户访问或使用的审计信息。
8、其它产生的数据库信息。
数据库数据字典是一组表和视图结构。它们存放在SYSTEM表空间中。
数据库数据字典不仅是每个数据库的中心。而且对每个用户也是非常重要的信息。用户可以用SQL语句访问数据库数据字典。
关于数据的信息集合,是一种用户可以访问的记录数据库和应用程序元数据的目录,是对数据库内表信息的物理与逻辑的说明。


在mysql中:CONCAT合并字符串只要有一个字符串为空,则输出为空;CONCAT_WS合并字符串,只要第一个字符串不为空,则输出不为空


count()函数有两种使用方式:1、使用count(*)对表中的行数进行计数,此种用法不忽略null值;2、使用count(column)对特定列中具有值的行进行计数,此种用法忽略null值。


  • 各分E-R图之间的冲突主要有:属性冲突,命名冲突,和结构冲突

数据库中:

  • ROUND(a,b) 函数用于把数值字段a舍入为指定的b小数位数,四舍五入;
  • TRUNCATE() 函数是按照小数位数进行数值截取没有四舍五入

ALTER TABLE table_name ADD INDEX index_name ( column )


  • 完全备份:所有都备份 。
  • 事物日志备份:自上次备份以来对数据库的改变,备份数据库的操作 。
  • 差异备份:自上次完全备份后所改变的数据库,备份的是数据 。
  • 文件备份:可进行部分备份。

E-R模型属于概念模型也即信息模型


  • DATEADD() 函数在日期中添加或减去指定的时间间隔
    语法: DATEADD(datepart,number,date)
  • datapart参数的取值范围是:{yy/yyyy,qq/q,mm/m,dy/y,dd/d,wk/ww,dw/w,hh,mi/n,ss/s,ms,mcs,ns}
  • number 是希望添加的间隔数
  • date 参数是合法的日期表达式

coalesce函数,返回第一个非空值,如果都是空,返回空值。


VARCHAR型字段(可变字段长度)的另一个突出的好处是它可以比CHAR型字段占用更少的内存和硬盘空间。当你的数据库很大时,这种内存和磁盘空间的节省会变得非常重要.
虽然VARCHAR使用起来较为灵活,但是从整个系统的性能角度来说,CHAR数据类型的处理速度更快,有时甚至可以超出VARCHAR处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡。


数据库管理系统(DBMS)最主要的功能是( 定义数据库)。


(1)PCTFREE:为一个块保留的空间百分比表示数据块在什么情况下可以被insert
(2)PCTUSED:是指当块里的数据低于多少百分比时又可以重新被insert
形象举例说明:
假如:一个杯子一共可装10分水:
PCTFREE = 10,说明杯子装到9分水,就不能再装了,即:不能进行insert操作,但可以进行update操作。
PCTUSED = 40,说明杯子中的水喝到4分一下,就可以往里面装水,即:进行insert操作。


外部并操作的概念是:如果R和S的关系模式不同,实现R与S的并操作所构成的新关系的属性由R和S的所有属性组成(公共属性只取一次),新关系的元组由属于R或属于S的元组所构成,同时元组在新增加的属性上填入空值


hash索引用于**=、in查询**,为确定值的查询
btree用于<、>和between的范围查询,并且支持排序


MySQL数据库中,变量分为 系统变量(以"@@"开头)和用户自定义变量。系统变量分为全局系统变量(global)和会话系统变量(session)。

  • @@global 仅用于访问全局系统变量的值;
  • @@session 仅用于访问会话系统变量的值;
  • @@ 先访问会话系统变量的值,若不存在则去访问全局系统变量的值;
    sql_mode 为系统变量,既是全局系统变量,又是会话系统变量。

& 位与运算,对于一个数(a)来说: a与1的结果如果为1,则这个数是奇数如果为0,则这个数是偶数


(摘)
rank() over()与dense_rank() over()的作用基本相同,都是对查出指定条件后的进行排名
rank() over()条件相同排名相同,排名间断不连续:1233567
区别在于dense_rank() over 排名是密集连续的:123345678
eg:

SELECT
score,
(rank() over ( ORDER BY score DESC )) AS rank FROM scores
select score, 
(dense_rank() over (order by Score desc)) AS "rank" from Scores;

ank是mysql的保留字段,会报错,错误码1064,解决方法是rank加上右撇引号rank


(摘)
A. RDBMS:(Relational Database Management System)关系数据库管理系统
B. NoSQL:非关系型的数据库
C. Nginx:是一个高性能的HTTP和反向web服务器,同时也提供了IMAP/POP3/SMTP服务
D. NewSQL:新型关系型数据库
E. ActiveMQ:Apache下的一个中间件
F. Hbase:是一个分布式的面向列的数据


语法结构:OVER( [ PARTITION BY … ] [ ORDER BY … ] )

1 、partition by 字段名字A:子句进行分组,partition by是固定的分组语法

2、order by 字段名字B:子句进行排序,order by 是固定的排序语法。

比如我们上面的例子就是用到了partition by classid 和 order by score这样的用法了,注意:如果联合使用指的意思是:先分组然后再排序

原文链接:


聚合函数之间不能嵌套使用


drop、delete、truncate的区别:
1:处理效率:drop>truncate>delete
2:删除范围:drop删除整个表(结构和数据一起删除);truncate删除全部记录,但不删除表结构;delete只删除数据
3:高水位线:delete不影响自增ID值,高水线保持原位置不动;truncate会将高水线复位,自增ID变为1。


between 和 and 关键字是闭区间


全文索引创建:FULLTEXT KEY title (title,content)
全文索引使用:如我们想要在article表的title和content列中全文检索指定的查询字符串,SQL如下:

SELECT * FROM article WHERE MATCH(title,content) AGAINST (‘查询字符串’);

SQL中正则表达式和模糊查询的使用:
一 . ‘%’ 可以替代0或者多个字符,放在不同位置作用不同

  1. select id from student where name like ‘李%’’(表示查找所有名字是‘李’开头的
  2. select id from student where name like ‘%李%’’(表示查找所有名字中间有‘李’的)
  3. select id from student where name like ‘%李’’(表示查找所有名字末尾有‘李’的)
    二.’_ ‘ 他是替代任意单个字符,放在不同位置作用不同,用法与’%’类似,这里就不赘述了

三. ‘**[ ] ‘ ,里面放任意字符列,**数量不限,表示满足括号内任意字符

注意:和上面两个不同的是这个通配符不再是与LIKE 一起使用了,他是正则里面的内容,所有用法稍有不同,他的前面要加上 regexp 关键字

F: select id from student where name regexp ‘[ 李王]’

表示查找所有名字中出现‘李’,或者‘王’的任意学生id

四.‘ [! ] ‘(也可以写成**[^ ]**)里面放任意字符列,**数量不限,表示满足除了括号内任意字符,这与上面一个相反,但是用法相似,

mysql中选择和投影运算习题 数据库中的选择和投影_mysql


^: 匹配输入字符串的开始位置

$: 匹配输入字符串的结束位置

[]: 匹配中括号里任意1个

|: 并集,就是或(or)


(摘)
在子表元素大于1时, 不能用= 要用in in(子表)


当遇到以下情况发生时,游标将自动设定INSENSITIVE 选项。
在SELECT 语句中使用DISTINCT、 GROUP BY、 HAVING UNION 语句;
使用OUTER JOIN;
所选取的任意表没有索引;
将实数值当作选取的列

INSENSITIVE表明MS SQL SERVER 会将游标定义所选取出来的数据记录存放在一临时表内(建立在tempdb 数据库下)。对该游标的读取操作皆由临时表来应答。因此,对基本表的修改并不影响游标提取的数据,即游标不会随着基本表内容的改变而改变,同时也无法通过游标来更新基本表。如果不使用该保留字,那么对基本表的更新、删除都会反映到游标中。


一个是空字符串,一个是NULL。针对这两种数据使用length()函数结果是不相同的。


  • 创建索引的语句是create index indexname on tablename (username (length))
  • 其中若是char和varchar类型,length可以小于字段实际长度,
  • 若是blob或text类型,必须指定length

复合索引: Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。


多级安全是指:给每一类数据设定一个安全级别,同时给每一类用户也设定安全级别,以此来控制什么级别的数据能被什么级别的用户访问。
强制安全性机制:通过对数据和用户强制分类,使不同类别的用户能访问到不同类型的数据;(数据分类)


删除列可以省略column,添加列必须说明数据类型