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

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: 快速学习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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
2月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
3月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
3月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
3月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
3月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
580 4
|
3月前
|
SQL 关系型数据库 MySQL
SQL批量插入测试数据的几种方法?
SQL批量插入测试数据的几种方法?
209 1
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
122 0
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
57 0
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
72 0
|
3月前
|
SQL
使用SQL进行集合查询和数据维护
使用SQL进行集合查询和数据维护
50 0