热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

SQL必知必会:数据库基本概念

数据库是一个以某种有组织的方式存储的数据集合。最简单的办法是将数据库想象为一个文件柜。这个文件柜是一个存放数据的物理位置,不管数据是什么,也不管数据是如何组织的。
数据库是一个以某种有组织的方式存储的数据集合。最简单的办法是将数 据库想象为一个文件柜。 这个文件柜是一个存放数据的物理位置,不管数据是什么,也不管数据是如何组织的。

数据库软件应称为数据库管 理系统(即 DBMS )。数据库是通过 DBMS 创建和操纵的容器。


表(table):某种特定类型数据的结构化清单。
这里关键一点就在于,存储在表中的数据是同一种类型的数据或清单,绝不可以将顾客的清单与订单的清单存储在同一个数据库表中。数据库中的每一个表都有一个名字来标识自己,这个名字是唯一的,即数据库中没有其他表具有相同的名字。虽然在相同数据库中不能使用相同名字,但在不同数据库中,可以使用相同名字。


表具有一些特性,这些特性定义了数据在表中如何存储,包含存储什么样的数据,数据如何分解,各部分信息如何命名等信息。描述表的这组信息就是所谓的模式。模式可以用来描述数据库中特定的表,也可以用来描述整个数据库。

模式:关于数据库和表的布局及特性的信息。


列和数据类型

表由列组成。列储存表中某部分的信息。

表中的一个字段,所有表都是由一个或多个列组成的。
理解列的最好办法就是将数据库表想象称为一个网格,就像电子表格那样。

提示:分解数据
正确地将数据分解为多个列极为重要。通过分解这些数据,才有可能利用特定的列对数据进行分类和过滤

数据库中每个列都有相应的数据类型,数据类型定义了列可以存储哪些数据种类,每个表列都有相应的数据类型。它限制(或允许)该列中存储的数据

数据类型限定了可存储在列中的数据种类。数据类型还帮助正确地分类数据,并在优化磁盘使用方面起重要的作用。

行:表中数据是按行存储的,所保存的每个记录存储在自己的行内,如果将表想象为网格,网格中的列为表列,水平行为表行。


主键

表中的每一行都应该有一列可以唯一地标示自己。顾客表可以使用顾客编号,订单表可以使用订单ID。

主键:一列,其值能唯一标识表中的每一行
唯一标识表中每行的这个列称为主键。主键用来标识一个特定的行。表中的任何列都可以作为主键,只要满足以下的条件:
  • 任意两行都不具有相同的主键值;
  • 每一行都必须具有一个主键值(主键列不允许NULL值);
  • 主键列的值不允许修改或更新;
  • 主键值不能重用(如果某行从表中删除,它的主键不能赋给以后的新行)
需要注意的是也可以一起使用多个列作为主键,在使用多列作为主键时,上述条件必须应用到所有列,所有列值的组合必须是唯一的(但单个列的值可以不唯一)。


SQL基础概念

SQL 是结构化查询语言,是一种专门用来与数据库沟通的语言。

优点:
  • SQL不是针对某个特定数据库供应商专有的语言。
  • SQL简单易学,它的语句全都是由有很强描述性英语单词组成。
  • SQL虽然看上去很简单。但实际上是一种强有力的语言。


推荐阅读
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • 本文详细介绍了如何使用libpq库与PostgreSQL后端建立连接。通过探讨PQconnectdb()函数的工作原理及其在实际应用中的使用方法,帮助读者理解并掌握建立高效、稳定的数据库连接的关键步骤。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
author-avatar
生如葳蕤_306
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有