数据库系统DBS、数据库管理系统DBMS、数据库管理员DBA
内模式:管理如何存储物理数据,对应具体物理存储文件
概念模式:通常使用的基本表,根据应用、需求将物理数据划分成一张张表
外模式:对应数据库的视图,将表处理后提供给用户使用
外模式-概念模式:表和视图的映射,修改了表中数据,只需要修改此映射,无需修改应用程序
概念模式-内模式:表和数据的物理存储的映射,修改了数据存储方式,只需修改此映射,无需修改应用程序
数据模型三要素:数据结构(所研究对象类型的集合)、数据操作(对数据库中各种对象的实例允许执行的操作的集合)、数据的约束条件(一组完整性规则的集合)
E-R模型:实体-联系模型,椭圆表示属性(一般没有)、矩形表示实体、菱形表示联系、联系两端要标注联系类型
联系类型:1:1、1:n、m:n
属性分类:简单属性和复合属性(属性是否可以分割)、单值属性和多值属性(属性有多个取值)、NULL属性、派生属性(由其他属性生成)
即数据库中的表,包括实体的属性,标示出实体的主键和外键
S(Sno, Sname, SDm Sagem Sex)学生
T(Tno, Tname, Age, Sex)教师
C(Cno, Cname, Pcno)课程
SC(Sno, Cno, Grade)学生选课
E-R图的每个实体都对应一个关系模式
给定一个X能唯一确定一个Y,就称X确定Y,或者说Y依赖于X,例如Y = X * X函数
完全函数依赖:AB能得出C,通过A、B单独不能得出C,则C完全依赖于AB
部分函数依赖:AB能得出C,AB中的一部分(A或B)也可以确定C**,称为部分函数依赖
传递函数依赖:AB不等价,A可确定B,B可确定C,则A可确定C,为传递函数依赖。若A和B等价,则不存在传递
超键:能唯一标识此表的属性的组合
候选键:超键中去掉冗余的属性,剩下的属性为候选键
主键:任意一个候选键
外键:其他表的主键
主属性:候选键内的属性为主属性,其他为非主属性
实体完整性约束:主键约束,主键值不能为空,也不能重复
参照完整性约束:外键约束,外键必须是其他表中存在的值,或者为空
用户自定义完整性约束:自定义表达式约束
从入度为零的节点寻找能遍历整个图的属性,就是候选字
范式之间的转换一般是拆分属性,即模式分解。将具有部分函数依赖和传递依赖的属性分离出来
事务提交commit、事务回滚rollback
事务由一系列操作组成,要么全做要么全不做
特点:
事务是并发控制的前提条件
三个问题:
三级封锁协议
X锁:排它锁,可读写其他事务不能加任何锁
S锁:共享锁,只能读其他事务只能加共享锁
一级封锁协议:修改前必须先加X锁,事务结束释放,解决丢失更新
二级封锁协议:以及的基础上读数据前先加S锁,读完后释放,解决丢失更新、读脏数据
三级封锁协议:二级加S锁后事务结束才释放,解决丢失更新、读脏数据、数据重复读
完全备份:备份所有数据
差量备份:备份上一次完全备份后变化的数据
增量备份:备份上一次备份后变化的数据
把所有操作写入日志文件,把数据缓冲区内容写入数据文件
分片模式:
分布透明性:
特殊的数据库,
数据源 --抽取清理装载刷新–> 数据仓库 --> 服务
发现剩余价值
方法:
BI 数据预处理(抽取转换加载ETL)、建立数据仓库、数据分析(联机分析OLAP、数据挖掘)、数据展现(可视化)
表拆分后不利于查询,所以反规范化以提高效率
创建表create table
指定主键primary key()
指定外键foreign key()
修改表alter table
删除表drop table
索引index
视图view
CREATE TABLE S(Sno CHAR(5) NOT NULL UNIQUE,
Sname CHAR(30) UNIQUE,
Status CHAR(8),
City CHAR(20)
PRIMARY KEY(Sno));
ALTER TABLE S ADD Zap CHAR(6);
DROP TABLE Student
CREATE UNIQUE INDEX S-SNO ON S(Sno);
CREATE VIEW CS-STUDENT
数据库查询select ... from ... where
分组查询 group by,分组时要注意select后的列名要适应分组,having为分组查询附加条件
select sno, avg(score) from student group by sno having(avg(score)>60)
更名运算as
select sno as "学号" from t1
字符串匹配like, %匹配多个字符串,_匹配任意一个字符串
select * from t1 where sname like'a_'
数据库插入insert into ... values()
insert into t1 values('a',66)
数据库删除delete from ... where
delete t1 where sno=4
数据库修改update ... set ... where
update t1 set sname='aa' where sno=3
排序order by,默认为升序,降序要加关键字DESC
select * from t1 order by sno desc
distinct 过滤重复的选项,只保留一条记录
union 出现在两条sql语句之间,将两个sql语句的查询结果取或运算
intersect 对两个sql语句的结果做与运算
min avg max 分组查询的聚合函数
select - pi
文章浏览阅读1.3k次。1. 网页元素介绍?元素: 由标签头+标签尾+标签头和标签尾包括的文本内容元素的信息就是指元素的标签名以及元素的属性元素的层级结构就是指元素之间相互嵌套的层级结构元素定位最终就是通过元素的信息或者元素的层级结构来进行元素定位。2. 浏览器开发者工具介绍浏览器开发者工作主要用来查看元素的信息, 同时也可以查看接口的相关信息。 浏览器开发者工作不需要安装,浏览器自带. 浏览器开发者工具的启动: 直接按F12 不区分浏览器 通过右键的方式来启动浏览器开发者工具 (谷歌浏览器右.._python ui自动化判断元素是否存在
文章浏览阅读29次。ioredis 作者@Luin宣布该项目已被 Redis 公司收购。目前 ioredis 在 GitHub 的开源地址已迁移至 Redis 公司旗下:ioredis 是一个用于 Node.js 的 Redis 客户端,健壮、性能好、功能强大且全面。两年前,ioredis超过redis 成为了 Node.js 最流行的 Redis 客户端。当时 ioredis 作者还感叹 redis 历经诸...
文章浏览阅读406次。3.如果一个可序列化对象包含了某个不可序列化对象的引用,那么整个序列化是会失败的,并且会抛出一个NotSerializableException,我们可以将这个引用标记为transient,表示为短暂的,此时该变量就无法被序列化,然后对象依旧可以被序列化。一个类如果想被序列化,则必须实现java.io.Serializable接口,这个接口没有定义任何方法,是一个标志性接口,当一个类实现了该接口,就表示这个类的对象是可以被序列化的。2.如果一个对象的成员变量是一个对象,那么这个对象的数据成员也会被保存。.._ser 序列化 反射
文章浏览阅读139次。zuul 路由1. zuul:1.1 zuul是什么?Zuul包含了对请求的路由和过滤两个最主要的功能:其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。注意:Zuul服务最终还是会注册进Eureka1.2 路由:_zuul: prefix: /api
文章浏览阅读2.1w次,点赞30次,收藏204次。摘要:在这个人人一部甚至多部智能手机的年代,各种APP充斥在各种应用市场作为一名电子爱好者或者电子工程师,你在为如何选择APP而头痛吗?哪些你正在使用的APP使你在工作、生活、学习中如虎添翼呢?现在,小师弟特意整理了一些电子爱好者和电子工程师能用到的手机APP和你没见过的电脑仿真软件。ElectroDroid电路专家ElectroDroid是一款电路电子器件的学习软件,比较专业化,它能够为你提供各种电路方面的信息查询和计算服务,是电子相关行业人士的必备工具之一。它包括:电阻色码计算器贴片电阻代码_电路仿真app
文章浏览阅读7.9k次,点赞9次,收藏53次。关于卷积神经网络的模型,我们这里只谈论关于图像分类的卷积神经网络的四种模型。在这里我们就不对卷积神经网络的结构进行阐述,不了解的同学可以参考我之前的博客LeNet-5首先我们先阐述的是1989年提出来的的LeNet-5结构。它其实就是最原始的结构,卷积层后衔接池化层,再接卷积层和其后的池化层,最后一个全连接层。(c1=convolution layer1,s1=subsampling layer1[降采样层,就是池化层])这个模型是实现识别手写数字的功能为目的而提出..._卷积神经网络模型
文章浏览阅读853次,点赞24次,收藏18次。到底什么是IaaS?它与PaaS和SaaS等其他云服务有何不同?本文将介绍它们之间的区别。随着91%的公司至少部分迁移到云,我们都应该对它们有基本了解。下面让我们探讨一下IaaS是什么,与其他云服务的区别,及一些实际使用中的示例。_google drive iaas
文章浏览阅读194次。滚动栏的范围是一对整数,默认情况下,滚动栏的范围是0~100。SetScrollRange(hwnd,iBar,iMin,iMax,bRedraw)这里的iBar參数要么是SB_VERT,要么是SB_HORZ,iMin和iMax分别相应滚动栏范围的最小值和最大值,须要Windows依据新的范围来重绘滚动栏时将bRedraw设为TRUE.SetScrollPos(hwnd..._setscrollerbarpos
文章浏览阅读1.3w次,点赞45次,收藏177次。入门awt不错的文章,带你快速上手awt_awt
文章浏览阅读170次。10.3int main(){ vector<string>v{ "Hello","World" }; auto sum = accumulate(v.begin(), v.end(), string{ "Tim Wu" }); cout << sum << endl;}int main(){ int v1 = 42; auto f ..._executionpolicy&&
文章浏览阅读1.1k次。在物联网浪潮之下,智能硬件的火爆程度不断升温。未来十年,全球接入互联网的硬件设备将达到1万亿台。如今的智能硬件产品正成为下一个“台风口”,同时这对于终端市场也是一个机遇。然而从创新走向产品,作为开发者应该如何步步为营?面对传统硬件与智能硬件之间思维理念及技术差异的“鸿沟”,开发者如何提升自己的技能,更加高效地开发?由此,我们带着探索道路上的种种疑问,采访了机智云 CTO ..._机智云科技有限公司刘焱
文章浏览阅读857次。跟随carl代码随想录刷题语言:python。_完全背包问题 输出有几种排列