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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
4月前
|
存储 SQL 关系型数据库
PolarDB这个sql行存和列存性能差别好大 ,为什么?
PolarDB这个sql行存和列存性能差别好大 ,为什么?
33 0
|
1月前
|
SQL 关系型数据库 分布式数据库
在PolarDB中,如果慢SQL导致了CPU升高,进而又产生了更多的慢SQL
【2月更文挑战第22天】在PolarDB中,如果慢SQL导致了CPU升高,进而又产生了更多的慢SQL
13 1
|
2月前
|
SQL 算法 JavaScript
【数据库SQL server】关系型数据库的基本知识
【数据库SQL server】关系型数据库的基本知识
150 0
|
4月前
|
SQL 关系型数据库 C语言
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
45 0
|
4月前
|
SQL 关系型数据库 数据库
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
49 0
|
4月前
|
SQL 关系型数据库 MySQL
MySQL【实践 02】MySQL迁移到PostgreSQL数据库的语法调整说明及脚本分享(通过bat命令修改mapper文件内的SQL语法)
MySQL【实践 02】MySQL迁移到PostgreSQL数据库的语法调整说明及脚本分享(通过bat命令修改mapper文件内的SQL语法)
102 0
|
4月前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
54 0
|
4月前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL【部署 01】离线安装PostgreSQL+PostGIS踩坑及问题解决经验分享(含安装文件PostgreSQL+PostGIS及多个依赖+测试SQL)
PostgreSQL【部署 01】离线安装PostgreSQL+PostGIS踩坑及问题解决经验分享(含安装文件PostgreSQL+PostGIS及多个依赖+测试SQL)
112 0
|
4月前
|
SQL NoSQL 关系型数据库
postgresql|数据库|SQL语句冲突的解决
postgresql|数据库|SQL语句冲突的解决
70 0
|
9月前
|
SQL Cloud Native 关系型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
737 1