数据库的基础概念

1、什么是数据库?

引用百度词条

  数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,是一个长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合,可视为电子化的文件柜。
  数据库技术是信息系统、办公自动化系统、决策支持系统等各类信息系统的核心部分,是进行科学研究和决策管理的重要技术手段。
  数据库管理系统(DBMS)是用来创建、运行和管理数据库的大型软件系统,它对数据库进行统一的管理和控制,以保证数据库的安全性和完整性。用户通过DBMS访问数据库中的数据,数据库管理员也通过DBMS进行数据库的维护工作。它可以支持多个应用程序和用户用不同的方法在同时或不同时候去建立,修改和询问数据库。
  此外,数据库的类型有很多,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。
  从数据存储方式来看,数据库分为关系型数据库和非关系型数据库两类。关系型数据库主要采用关系模型来存储结构化数据,如Oracle、MySQL、Microsoft SQL Server等;非关系型数据库则主要采用非关系模型来存储非结构化数据,如键值数据库、文档型数据库、图数据库等。

  • 数据结构:主要描述数据的类型、内容、性质以及数据间的联系等,是目标类型的集合
  • 数据操作:主要描述在相应的数据结构上的操作类型和操作方式
  • 数据约束:主要描述数据结构内数据间的语法、词义联系、他们之间的制约和依存关系,以及数据动态变化的规则,以相容保证数据的正确、有效和相容性

20世纪70年代关系模型首次提出
Oracle 数据库:1983年推出的第一个开放式商品化关系型数据库,主要应用银行、金融、保险等大型开发场景
MySQL 数据库:是最流行的关系型数据库,主要应用中小型网站,尤其是 Web 应用程序开发
SQL Server 数据库:是微软公司推出的一款数据库,主要应用银行、金融、保险等大型开发场景

主流的非关系型数据库
Redis 数据库:采用的键值存储形式的数据库,数据存储在内存中,并可以持久化到硬盘当中,常用于应用程序中的数据缓存、排行榜、计数器等场景的开发。
MongoDB 数据库:是一种基于文档对象存储的数据库产品,支持非结构化数据和JSON文档存储,能够更简单和便捷地处理复杂的数据,常用于应用程序的内容管理、目录、日志等场景的开发。

2、SQL 语言功能分类

  • DDL(数据定义语言):用来定义数据库对象,数据库,表,列等。比如关键字:create,alter,rename等。
  • DML(数据操作语言):用来对数据库中表的记录进行更新。比如关键字insert,delete,update等
  • DCL(数据控制语言):用来定义数据库的访问权限和安全级别,及创建用户。比如关键字: commit、rollback 等
  • DQL(数据查询语言):用来查询数据库中表的记录。比如关键字:select,from,where等

3、SQL 中的注释

单行注释 – 注释内容 (–后面必须要跟一个空格)
多行注释 /*注释内容 */

4、基本概念

主键
又称为主码,是用于唯一地标识表中的一条记录可以通过表中的一列或者多列进行定义,主键是不能重复值,也不能为空
索引
索引是数据表中某个字段的索引,在创建好数据表之后,可以为某个字段添加索引或者为多个字段联合添加一个索引,索引的作用就是提高查找的效率,数据库会自动为数据表中的主键字段添加索引对象,关于索引的使采用的一种方式用在数据库优化时是经常采用的一种方式
视图和表的区别
在操作层面上,数据表可以进行数据的增删改查,而视图只能进行查操作
我们删除和创建视图,对于数据表是没有任何影响的,但是删除数据表对某个视图是可能有影响的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/850888.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统推出VB6开发IDE了?Gambas,Linux脚本编写

第一个Linux程序,加法计算加弹窗对话框,Gambas,linux版的类似VB6的IDE开发环境 一开始想用VB6的Clng函数转成整数,没这函数。 输入3个字母才有智能提示,这点没做好 没有msgbox函数,要用messagebox.warning 如果可以添加函数别名就…

uniapp 使用秋云ucharts,实现线状图横线滚动

其实仔细阅读官网说明文档&#xff0c;能找到答案&#xff0c;但是咱们着急实现功能&#xff0c;直接点上代码。 *标签上注意的是需要设置:ontouch"true"* <view class"" style"width:100%;height:610rpx;"><qiun-data-charts type&q…

[书生·浦语大模型实战营]——第六节 Lagent AgentLego 智能体应用搭建

1. 概述和前期准备 1.1 Lagent是什么 Lagent 是一个轻量级开源智能体框架&#xff0c;旨在让用户可以高效地构建基于大语言模型的智能体。同时它也提供了一些典型工具以增强大语言模型的能力。 Lagent 目前已经支持了包括 AutoGPT、ReAct 等在内的多个经典智能体范式&#x…

通过双模式对抗提示越狱视觉语言模型

最近&#xff0c;将视觉整合到大型语言模型&#xff08;LLMs&#xff09;中的兴趣显著增加&#xff0c;催生了大型视觉语言模型&#xff08;LVLMs&#xff09;。这些模型结合了视觉和文本信息&#xff0c;如LLaVA和Gemini&#xff0c;已经在包括图像字幕、视觉问题回答和图像检…

论文阅读:All-In-One Image Restoration for Unknown Corruption

发表时间&#xff1a;2022 cvpr 论文地址&#xff1a;https://openaccess.thecvf.com/content/CVPR2022/papers/Li_All-in-One_Image_Restoration_for_Unknown_Corruption_CVPR_2022_paper.pdf 项目地址&#xff1a;https://github.com/XLearning-SCU/2022-CVPR-AirNet 代码解读…

c++中, 直接写浮点数, 是float 还是 double?

如果直接一个浮点数, 那么他默认是float还是double呢? 测试用例 #include <iostream> using namespace std;int main() {auto x 0.2;float f 0.2;double d 0.2;cout << "x Size : " << sizeof(x) << " bytes" << endl…

vue28:组件化开发和根组件

简单写个点击事件 <template> <div class"app"><div class"box" click"fn"></div></div> </template><script> export default {//导出当前组件的配置项//里面可以提供 data methods computed wat…

AtCoder Beginner Contest 356 G. Freestyle(凸包+二分)

题目 思路来源 quality代码 题解 对n个泳姿点(ai,bi)建凸包&#xff0c;实际上是一个上凸壳&#xff0c; 对于询问(ci,di)来说&#xff0c;抽象画一下这个图&#xff0c;箭头方向表示询问向量 按x轴排增序&#xff0c;并且使得后面的y不小于前面的y&#xff0c;因为总可以多…

java asm使用切面

在Java中&#xff0c;使用ASM框架实现切面主要涉及到字节码操作和运行时动态代理。ASM是一个流行的Java字节码操作库&#xff0c;它允许开发者在编译时期或运行时期修改类和方法的行为。以下是使用ASM实现切面的方法&#xff1a; ### 一、引入依赖 首先&#xff0c;在你的项目中…

C++ Easyx案例实战:Cookie Maker工作室1.0V

前言 //制作属于自己的工作室&#xff01; 注&#xff1a;运行效果以及下载见Cookie Maker 工作室成立程序。 关于Cookie Maker工作室成立的信息&#xff0c;I am very happy&#xff08;唔……改不过来了&#xff09;。 OKOK&#xff0c;第一次用图形库写程序&#xff08;图形…

【Maxcompute】数据封装json、根据经纬度计算距离、根据证件号提取年龄段信息、判断是否在外包多边形内udf、udtf函数

1.梳理、总结经纬度处理在Maxcompute平台上的实战应用&#xff0c;如模型结果等封装json格式、根据经纬度计算距离udf、根据证件号提取年龄段信息、判断是否在外包多边形内udf、udtf、函数注册与使用。 2.欢迎批评指正&#xff0c;跪谢一键三连&#xff01; 文章目录 1.参考代码…

Java之数据库连接桥梁JDBC学习笔记

JDBC调用 Java与数据库的连接桥梁是JDBC&#xff08;Java Database Connectivity&#xff09;。JDBC是Java编程语言中用于连接和执行数据库操作的API&#xff08;应用程序编程接口&#xff09;。它提供了一种标准的方法&#xff0c;允许Java程序与各种数据库&#xff08;如MyS…

在开源处理器架构RISC-V中发现可远程利用的中危漏洞

在RISC-V SonicBOOM处理器设计中发现中度危险的漏洞 最近&#xff0c;西北工业大学的网络空间安全学院胡伟教授团队在RISC-V SonicBOOM处理器设计中发现了一个中度危险的漏洞。这个团队的研究人员发现了一个可远程利用的漏洞&#xff0c;该漏洞存在于开源处理器架构RISC-V中。…

C++中实现一个泄漏检测工具

在C++中实现一个泄漏检测工具是一个复杂但有趣的任务。这通常涉及到重写或拦截内存分配和释放函数,以及跟踪所有内存分配的情况。以下是一个简单的泄漏检测工具的实现思路: 重写new和delete操作符: 你可以通过重载全局的new和delete操作符来跟踪内存分配和释放。这需要创建一…

单灯双控开关原理

什么是单灯双控&#xff1f;顾名思义&#xff0c;指的是一个灯具可以通过两个不同的开关或控制器进行控制。 例如客厅的主灯可能会设置成单灯双控&#xff0c;一个开关位于门口&#xff0c;另一个位于房间内的另一侧&#xff0c;这样无论你是从门口进入还是从房间内出来&#x…

Kafka面试题及答案

Kafka是一个开源的分布式流处理平台&#xff0c;被广泛应用于大数据领域。由于其高性能、高可靠性和可扩展性&#xff0c;Kafka成为了很多公司工程师面试的热门话题。如果你准备面试Kafka相关的职位&#xff0c;下面是一些你可能会遇到的常见问题及其解析。 Kafka的基本概念是…

java web:springboot mysql开发的一套家政预约上门服务系统源码:家政上门服务系统的运行流程

java web&#xff1a;springboot mysql开发的一套家政预约上门服务系统源码&#xff1a;家政上门服务系统的运行流程 家政上门服务系统的优势 服务质量更稳定&#xff1a;由专业的家政人员提供服务&#xff0c;经过严格的培训和筛选。 价格更透明&#xff1a;采用套餐式收费&…

Vue3+TS 开发 Google 浏览器插件模板

最近做个产品小 demo 需要开发浏览器插件&#xff0c;默认情况下开发插件是要采用 html、css、js…我不太习惯&#xff0c;找了一下浏览器插件也是有开发框架的&#xff0c;例如&#xff1a;WXT、Plasmo 等。 不过综合对比考虑使用了开源大佬封装的 create-vue-chrome-ext 来开…

linux install cmake3.22

在Linux上安装CMake 3.22的步骤如下&#xff1a; 下载CMake 3.22的源代码。 解压源代码。 构建并安装CMake。 以下是具体的命令&#xff1a; # 下载CMake 3.22 wget https://github.com/Kitware/CMake/releases/download/v3.22.0/cmake-3.22.0.tar.gz # 解压源代码 tar…

RISC-V基础编译

RISCV编译 1、 编译步骤2、重要配置3、elf-gcc和linux-gnu-gcc的区别1、 编译步骤 mkdir build installcd build../riscv-gnu-toolchain/configure --prefix=/xxx/install --with-arch=rv32gc --with-abi=ilp32d --enable-debugmake linux //linux工具链make newlib //编译n…