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

简介: 快速学习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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
SQL 关系型数据库 MySQL
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性
|
3月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
3月前
|
算法 数据挖掘 数据库
通过 SQL 快速使用 OceanBase 向量检索学习笔记
通过 SQL 快速使用 OceanBase 向量检索学习笔记
|
3月前
|
SQL 数据库
SQL 学习笔记 - 多表关系与多表查询
数据库多表关系包括一对多、多对多和一对一,常用外键关联。多表查询方式有隐式/显式内连接、外连接、子查询等,支持别名和条件筛选。子查询分为标量、列、行、表子查询,常用于复杂查询场景。
|
SQL 存储 关系型数据库
RDS for MySQL的SQL分类与数据类型
小明需在MySQL中管理商品信息,使用SQL完成业务操作。SQL分为DQL(查询)、DML(增删改)、DDL(定义)、DCL(权限控制)和TCL(事务)五大类。DDL用于创建、修改和删除数据库结构,DML处理数据,DCL控制权限,TCL管理事务,DQL则用于查询数据。MySQL有多种数据类型,如数值型(整数、小数)、日期型和字符串型等,选择合适的数据类型是高效开发的关键。
241 0
|
存储 SQL 自然语言处理
|
SQL 存储 关系型数据库
SQL分类与数据类型
【7月更文挑战第12天】Mysql SQL语句分类与数据类型 介绍
|
存储 SQL 数据库
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
1626 0
|
SQL 关系型数据库 Linux
PostgreSQL基础之psql的使用
PostgreSQL基础之psql的使用
836 0

热门文章

最新文章

推荐镜像

更多