3 PostgreSQL psql的使用,SQL语法,数据类型,递归SQL用法(三)|学习笔记

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介: 快速学习3 PostgreSQL psql的使用,SQL语法,数据类型,递归SQL用法(三)

开发者学堂课程【PostgreSQL快速入门:3 PostgreSQL psql的使用,SQL语法,数据类型,递归SQL用法(三)】学习笔记与课程紧密联系,让用户快速学习知识

课程地址https://developer.aliyun.com/learning/course/16/detail/89


3 PostgreSQL psql的使用,SQL语法,数据类型,递归SQL用法(三)

 

内容介绍

、PostgreSQL表操作

、事务操作

、单条SQL插入多行


五、PostgreSQL表操作

1、SQL Syntax-Lexical Structure

执行sql语句时分为几个部分

例子

SELECT * FROM pg_class WHERE relname = 'pg_statistic' LIMIT 1;  is one comment

TOKEN

keyword (SELECT FROM WHERE LIMIT)所有的关键字参考数据库手册

identifier or quoted identifier (pg _class relname,表名,列名,对象名..)常量字符串

默认小写,如需大写需使用双引号强烈建议不要使用大写不要用双引号会引发很多不必要的麻烦

literal or constant ('pg_ _statistic' 1)

special character symbol (*) 特殊字符所有的字段

comment (-- is one-line comment) or (/* */ multi-line comment)两个减号后的字符都做注释多行的注解

operator (=)操作符对应数据类型的某一个函数

比如1=1的数据类型对应的是int4eq的函数字符串对应的是texteq

identifier最大长度受以下限制

define NAMEDATA EN 64 (长度限制截断到63)比如支持128位的表名数字改成129即可

truncate_ identifier(char *ident, int len, bool warn)

{

if(len >= NAMEDATALEN)

{

len = pg _mbcliplen(ident, len, NAMEDATALEN- 1);

if(warn)

{

Char buf[NAMEDATALEN];字节的意思

memepy(buf, ident, len);

Buf[len]= \0;

ereport(NOTICE,

(errcode(ERRCODE_NAME_ TOO_ LONG),

errmsg("identifier\"%s\" will be truncated to \"%s\"",

ident, buf)));

}

ident[len] = "\0';

}

}

2、改变最大长度限制,需重新gitdb改完重新编译

src/include/pg_ config_ manual.h

/*

* Maximum length for identifiers (e.g. table names, column names,

* function names). Names actually are limited to one less byte than this,

* because the length must include a trailing zero byte.

* Changing this requires an initdb.

*/

#define NAMEDATALEN 64

3、implicitly-typed literal or constant常量输入比如隐式的常量隐式的转换

(1)string

E'digoa\\'

$$digoal$$

$tag$digoal\$tag$

(2)bit string

B'1010101'

(3)number

10 or+10

-23.4

+100.1 or 100.1

10e-1

98e+10 or 98e10

4、explicit-typed literal or constant显式的转换

type 'string'单引号中间是字符

time '12:00:00'

'string' ::type

'1 hour'::interval

CAST( 'string' AS type )

CAST('127.0.0.1' AS inet);做强制转换

5、操作符

+-*/<>=~!@#%^&|'?||

查询

postgres=# select count(*) from pg_ operator;

count

706

也可以使用这种用法,解析器同样支持。操作符如果是自定义的不是放在默认的系统下面可以指定它

SELECT 3 OPERATOR(pg_catalog.+)4;

6、特殊符号

$

string quoted用来把字符串扩起来作为变量的前导符号

positional parameter in function or prepared statement

Prepare  p1 <int> as select*from t where id=$1;

Excute p1<1>;

把p1替换成int,$1表示第一个变量的意思

()

enforce precedence强制的优先级

[]

array selected elements保留特殊字符

separate the elements of a list表示把元素分开

terminate a SQL结束sql语句

slice from array数组下标的分隔符

*

all the fields of a table or composite value所有的表复合类型

.

numeric , separate schema, table, column names.在数字里面表示一个小数点复合类型可以column.复合类型的名字

 

六、事务操作

事务相关的TOKEN

BEGIN; -可指定事务隔离级别,事务读写属性,约束延迟校验属性等

COMMIT;

ROLLBACK;

SAVEPOINT a;

ROLLBACK to a;

二阶事务相关TOKEN,

prepare transaction

rollback prepared回滚掉前面已经结束的rollback prepared的二阶事务

commit prepared提交一个二阶事务

psq|相关的事务模式变量

ON_ ERROR_ ROLLBACK, ON_ ERROR STOP

postgres- # \set ON_ ERROR_ ROLLBACK on

当在prostgre里面执行语句时在事务中遇到一个错误都要回滚还可以继续执行那条错误相当于直接回避掉跟ON_ ERROR_ ROLLBACK有关系如果开启ON_ ERROR ROLLBACK,会在每一句SQL前设置隐形的savepoint,可以继续下面的SQL,而不用全部回滚

语法已经报错还可以往t表加数据还可以提交如果关闭设置成off再往里面插数据会提示不可以插数据必须要回滚否则不能继续下去会一直报错

 

七、单条SQL插入多行

INSERT INTO tbl(c1...cn) values(...),(...),...,(...);

例如

digoal=# drop table user_ info;

DROP TABLE

digoal =# create table user_ info(id int, info text);

CREATE TABLE

digoal=#insert into user_info(id,info) values( 1,'test')(1'test')(1,test')(1,test'),(1,test);

INSERT0 5

digoal # select ctid,cmin,cmax,xmin,xmax,* from user_ info;

ctid I cmin Icmax I xminI xmax id Iinfo --几个隐含字段的简单解释这种sql的好处Cmin id完全一样就表示值在同一个sql语句上效率高批量提交考虑用这种方式

(0,1)I 14I 14 I21673245410I11 Itest

(0,2)I 14I 14I21673245410I11 Itest

(0,3)I 14I 14 I2167324540I11 Itest

(0,4)I 14I 14I216732454 0I11 Itest

(0,5)I 14I 14I216732454 0I11 Itest

(5 rows)

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
5天前
|
SQL 存储 Oracle
Oracle的PL/SQL定义变量和常量:数据的稳定与灵动
【4月更文挑战第19天】在Oracle PL/SQL中,变量和常量扮演着数据存储的关键角色。变量是可变的“魔术盒”,用于存储程序运行时的动态数据,通过`DECLARE`定义,可在循环和条件判断中体现其灵活性。常量则是不可变的“固定牌”,一旦设定值便保持不变,用`CONSTANT`声明,提供程序稳定性和易维护性。通过 `%TYPE`、`NOT NULL`等特性,可以更高效地管理和控制变量与常量,提升代码质量。善用两者,能优化PL/SQL程序的结构和性能。
|
25天前
|
SQL 存储 关系型数据库
一文搞懂SQL优化——如何高效添加数据
**SQL优化关键点:** 1. **批量插入**提高效率,一次性建议不超过500条。 2. **手动事务**减少开销,多条插入语句用一个事务。 3. **主键顺序插入**避免页分裂,提升性能。 4. **使用`LOAD DATA INFILE`**大批量导入快速。 5. **避免主键乱序**,减少不必要的磁盘操作。 6. **选择合适主键类型**,避免UUID或长主键导致的性能问题。 7. **避免主键修改**,保持索引稳定。 这些技巧能优化数据库操作,提升系统性能。
220 4
一文搞懂SQL优化——如何高效添加数据
|
1月前
|
SQL 关系型数据库 MySQL
TiDB支持的SQL语法概述
【2月更文挑战第28天】本章将对TiDB所支持的SQL语法进行概述,涵盖其主要的语法特性和功能。我们将从基本的SQL语句到更复杂的查询和操作,逐步介绍TiDB的SQL语法,帮助读者更好地理解和使用TiDB进行数据库操作。
|
2月前
|
SQL 存储 数据管理
阿里云视觉智能开放平台的逻辑数仓基于统一的SQL语法
【2月更文挑战第9天】阿里云视觉智能开放平台的逻辑数仓基于统一的SQL语法
52 2
|
1月前
|
SQL 数据库
sql server中创建数据库和表的语法
sql server中创建数据库和表的语法
18 1
|
1月前
|
SQL 数据可视化 数据处理
使用SQL和Python处理Excel文件数据
使用SQL和Python处理Excel文件数据
54 0
|
1月前
|
SQL 存储 关系型数据库
SQL的基本语法以及SQL语句的关键字的使用,SELECT、INSERT、UPDATE、DELETE、CREATE、ALTER、DROP等。
SQL的基本语法以及SQL语句的关键字的使用,SELECT、INSERT、UPDATE、DELETE、CREATE、ALTER、DROP等。
|
5天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL游标属性:数据的“导航仪”与“仪表盘”
【4月更文挑战第19天】Oracle PL/SQL游标属性如同车辆的导航仪和仪表盘,提供丰富信息和控制。 `%FOUND`和`%NOTFOUND`指示数据读取状态,`%ROWCOUNT`记录处理行数,`%ISOPEN`显示游标状态。还有`%BULK_ROWCOUNT`和`%BULK_EXCEPTIONS`增强处理灵活性。通过实例展示了如何在数据处理中利用这些属性监控和控制流程,提高效率和准确性。掌握游标属性是提升数据处理能力的关键。
|
5天前
|
SQL Oracle 安全
Oracle的PL/SQL循环语句:数据的“旋转木马”与“无限之旅”
【4月更文挑战第19天】Oracle PL/SQL中的循环语句(LOOP、EXIT WHEN、FOR、WHILE)是处理数据的关键工具,用于批量操作、报表生成和复杂业务逻辑。LOOP提供无限循环,可通过EXIT WHEN设定退出条件;FOR循环适用于固定次数迭代,WHILE循环基于条件判断执行。有效使用循环能提高效率,但需注意避免无限循环和优化大数据处理性能。掌握循环语句,将使数据处理更加高效和便捷。
|
5天前
|
SQL Oracle 关系型数据库
Oracle的PL/SQL条件控制:数据的“红绿灯”与“分岔路”
【4月更文挑战第19天】在Oracle PL/SQL中,IF语句与CASE语句扮演着数据流程控制的关键角色。IF语句如红绿灯,依据条件决定程序执行路径;ELSE和ELSIF提供多分支逻辑。CASE语句则是分岔路,按表达式值选择执行路径。这些条件控制语句在数据验证、错误处理和业务逻辑中不可或缺,通过巧妙运用能实现高效程序逻辑,保障数据正确流转,支持企业业务发展。理解并熟练掌握这些语句的使用是成为合格数据管理员的重要一环。