openGauss数据库SQL基本语法
目录
一、什么是SQL?
1、SQL的概念
2、SQL的特点
3、SQL发展简史
二、openGauss数据库的“SQL”
1、数据类型(常用)
数值类型
货币类型
布尔类型
字符类型
日期/时间类型
2、openGauss数据库SQL基本语法
创建用户(CREATEUSER)
创建和管理数据库
创建表(CREATETABLE)
向表中插入数据
更新表中数据
查看数据
删除表中数据
三、参考资料:
一、什么是SQL?
1、SQL的概念
结构化查询语言(SQL)是用于访问和处理关系型数据库的标准计算机语言。
SQL提供了各种任务的语句,包括:
查询数据。
在表中插入,更新和删除行。
创建,替换,更改和删除对象。
控制对数据库及其对象的访问。
保证数据库的一致性和完整性。
SQL语言由用于处理数据库和数据库对象的命令和函数组成:
DDL(datadefinitionlanguage)数据定义语言,用户定义和管理sql数据库中所有对象的语言。主要命令:create、alter、drop等
DML(datamanipulationlanguage)数据操作语言。主要命令:select、update、insert、delete等
DCL(datecontrollanguage)数据库控制功能。主要命令:grant、deny、revoke、commit、savepoint、rollback等
2、SQL的特点
SQL语言集数据查询、数据操纵、数据定义和数据控制功能于一体
面向集合的语言
非过程语言
类似自然语言,简洁易用
自含式语言,又是嵌入式语言。可独立使用,也可嵌入到宿主语言中。
3、SQL发展简史
SQL发展简史如下:
1986年,ANSIX3.135-1986,ISO/IEC9075:1986,SQL-86
1989年,ANSIX3.135-1989,ISO/IEC9075:1989,SQL-89
1992年,ANSIX3.135-1992,ISO/IEC9075:1992,SQL-92(SQL2)
1999年,ISO/IEC9075:1999,SQL:1999(SQL3)
2003年,ISO/IEC9075:2003,SQL:2003(SQL4)
2011年,ISO/IEC9075:200N,SQL:2011(SQL5)
//注:
ANSI是美国国家标准学会(AmericanNationalStandardsInstitute)的英文简称,成立于1918年。
ISO:国际标准化组织(InternationalOrganizationforStandardization)。
IEC:国际电工委员会(InternationalElectrotechnicalCommission)。
//
二、openGauss数据库的“SQL”
openGauss数据库支持的SQL标准,默认支持SQL2、SQL3和SQL4的主要特性。当然了,一般说到数据库的SQL语句,就离不开两个方面:一是数据类型,二是sql语句基本语法。下文就此简单阐述一下:
1、数据类型(常用)
openGauss数据库支持的数据类型涵盖非常广,几乎包含所有形式的数据类型,如:数值类型、货币类型、布尔类型、字符类型、二进制类型、日期/时间类型、几何类型、网络地址类型、位串类型、文本搜索类型、UUID类型、JSON/JSONB类型、HLL数据类型、范围类型、对象标识符类型、伪类型、列存表支持的数据类型、XML类型、账本数据库使用的数据类型等。但是实际业务场景中大部分类型用到的比较少,具体遇到时可参考官方文档说明。
下文参考并整理了日常应用开发中常用的主要数据类型,主要包含:数值类型、货币类型、布尔类型、字符类型、日期/时间类型等。
表1:整数数据类型
名称
描述
存储空间
范围
TINYINT
微整数,别名为INT1。
1字节
0~255
SMALLINT
小范围整数,别名为INT2。
2字节
-32,768~+32,767
INTEGER
常用的整数,别名为INT4/BINARY_INTEGER。
4字节
-2,147,483,648~+2,147,483,647
BIGINT
大范围的整数,别名为INT8。
8字节
-9,223,372,036,854,775,808~+9,223,372,036,854,775,807
字节
~
+170,141,183,460,469,231,731,687,303,715,884,105,727
说明:TINYINT、SMALLINT、INTEGER、BIGINT和INT16类型存储各种范围的数字,也就是整数。试图存储超出范围以外的数值将会导致错误。
常用的类型是INTEGER,因为它提供了在范围、存储空间、性能之间的最佳平衡。一般只有取值范围确定不超过SMALLINT的情况下,才会使用SMALLINT类型。而只有在INTEGER的范围不够的时候才使用BIGINT,因为前者相对快得多。
版权声明
本文仅代表作者观点,不代表博信信息网立场。