【数据库原理】(9)SQL简介

一.SQL 的发展历史

  • 起源:SQL 起源于 1970 年代,由 IBM 的研究员 Edgar F. Codd 提出的关系模型概念演化而来。
  • 初期:Boyce 和 Chamberlin 在 IBM 开发了 SQUARE 语言的原型,后发展成为 SQL。这是为了更好地利用和管理关系数据库。
  • System R:1970年代末,IBM 的 San Jose Research Laboratory 开发了 System R,这是第一个实现 SQL 作为查询语言的关系数据库管理系统原型。

二.SQL的特点

  1. 综合统一

    • SQL 能够处理数据库的定义、操作和控制,这意味着可以使用同一种语言来创建表结构、插入、查询、更新数据,以及设置访问权限和安全性控制。
    • 这种一体化设计提高了效率,减少了学习不同语言的需要。
  2. 高度非过程化

    • SQL 用户不需要指定如何达到一个数据操作的目的,只需要声明他们想要的结果。
    • 这种声明式的特点使得 SQL 用户无需担心底层数据的存储方式和访问路径,从而简化了数据库操作。
  3. 面向集合的操作方式

    • SQL 操作是基于集合的,这意味着可以一次处理一组数据(例如,一次检索、更新或删除多个记录)。
    • 这与一些早期的、面向记录的数据库语言形成对比,后者每次只能操作单个记录。
  4. 以同一种语法结构提供两种操作方式

    • SQL 既可以作为独立的查询语言使用,也可以嵌入到其他编程语言中,如 C、Java 或 Python。
    • 这种灵活性使得 SQL 既可以满足简单的数据库查询需求,也能够在复杂的应用程序中发挥作用。
  5. 语言简洁,易学易用

    • SQL 语法结构简单明了,接近自然语言,这使得学习和使用 SQL 相对容易。
    • 尽管功能强大,但 SQL 的核心部分只包含一些基本的关键词和语法规则。

三.SQL语言简介

  1. 常量

    • 包括字符串、数字等。它们是查询中直接使用的值,如 'Hello World'100 等。
  2. 数据类型

    • 定义表中列的数据类型,例如整型(INT)、字符型(CHARVARCHAR)、数值型(NUMERICFLOAT)等。不同数据库可能支持不同的数据类型。
数据类型 说明符号 注释
整型 INT 定长16位
长整型 LONG 定长32位
十进制数 NUMBERIC(m,n) m为十进制位数,n为小数点位数
浮点数 FLOAT 定长64位(双精度)
字符型(定长) CHAR(n) 按固定长度n存储字符串,自动补充空格
变长字符型 VARCHAR(n) 按实际长度n存储字符串
日期型 DATE 格式为:yyyymmdd(年月日)
时间型 TIME 格式为:hhmmss(时分秒)
  1. 运算符

    • 用于构建表达式,包括算术运算符(如 +, -, *, /)、比较运算符(如 =, <>, >)、逻辑运算符(如 AND, OR, NOT),字符串运算符(||),集合运算符(UNION、INTERSECT、MINUS)等。
  2. 函数

    • 提供数据处理功能,如字符串函数、数学函数、聚合函数(如 SUM(), COUNT() 等)。
    • 一般函数引用形式:函数名([DISTINCT/ALL<表达式>])
  3. 谓词

    • 用于构建复杂的条件表达式,如 BETWEEN, IN, LIKE 等,以支持更灵活的数据查询。
  4. 表达式

    • 由值、函数和运算符组成的结构,可以计算得出一个结果。
  5. 条件

    • 用于在 WHEREHAVING 等子句中定义数据过滤的逻辑条件。
  6. 命令

    • SQL 的核心部分,包括数据定义命令(如 CREATE, ALTER, DROP)、数据操纵命令(如 SELECT, INSERT, UPDATE, DELETE)和数据控制命令(如 GRANT, REVOKE)。
相关推荐
切糕师学AI6 小时前
SQL中的函数索引/表达式索引
数据库·sql·mysql·postgresql·oracle
武子康7 小时前
Java-166 Neo4j 安装与最小闭环 | 10 分钟跑通 + 远程访问 Docker neo4j.conf
java·数据库·sql·docker·系统架构·nosql·neo4j
S_h_a_7 小时前
八股-Mysql 基础篇(1)
数据库·mysql
Dxy12393102167 小时前
MySQL的GROUP_CONCAT函数详解
数据库·mysql
编啊编程啊程7 小时前
【029】智能停车计费系统
java·数据库·spring boot·spring·spring cloud·kafka
Leon-Ning Liu8 小时前
Oracle数据库常用视图:dba_datapump_jobs
数据库·oracle·dba
数据库生产实战8 小时前
Oracle 19C RAC下TRUNCATE TABLE的REUSE STORAGE选项作用和风险浅析!
数据库·oracle
小白银子9 小时前
零基础从头教学Linux(Day 60)
linux·数据库·mysql·oracle
瀚高PG实验室9 小时前
数据库安全配置指导
服务器·数据库·瀚高数据库
憋问我,我也不会9 小时前
MYSQL 命令
数据库·mysql