执行环境: psql
1. 创建一个表格
CREATE TABLE customers (
customer_id serial PRIMARY KEY,
firstname VARCHAR(100) NOT NULL,
lastname VARCHAR(100) NOT NULL,
username VARCHAR(50) UNIQUE NOT NULL,
password VARCHAR(50) NOT NULL,
email VARCHAR(255) UNIQUE NOT NULL,
created_on TIMESTAMPTZ NOT NULL
);
- customer_id:这是一个序列,意味着它将自动递增,用作主键,用来唯一标识每个客户。
- created_on:这是一个不允许为空的日期时间字段,用来存储客户的创建时间。
2. 插入
INSERT INTO customers(firstname, lastname, username, password, email, created_on)
VALUES('Elizabeth', 'Banks', 'elizabethbanks', '4s$5eks9m', 'elizabethbanks@myemail.com', CURRENT_TIMESTAMP);
SELECT * FROM customers;
data:image/s3,"s3://crabby-images/cc1c2/cc1c292fb16fe086bf841813d2d636e3d6c11fa9" alt="在这里插入图片描述"
插入两条记录
INSERT INTO customers(firstname, lastname, username, password, email, created_on)
VALUES('Nicole', 'Kidman', 'nkidman', '392kMLK!m', 'nicole@kidman.com', CURRENT_TIMESTAMP),
('Leroy', 'Jenkins', 'leeroy', '4k2ln@Lm', 'leroy@email.com', CURRENT_TIMESTAMP);
SELECT * FROM customers;
data:image/s3,"s3://crabby-images/5b8a7/5b8a748ab3fc2d24e4cb894c68b8b83e143e55c3" alt="在这里插入图片描述"
3. 修改
UPDATE customers
SET username='aliceinwonderland'
WHERE email=
'elizabethbanks@myemail.com';
SELECT * FROM customers;
data:image/s3,"s3://crabby-images/35c45/35c4581a4eaa91ee0b2236f6029cd731977a9a96" alt="在这里插入图片描述"
4. 查找
SELECT * FROM customers WHERE username='aliceinwonderland';
data:image/s3,"s3://crabby-images/c8e4e/c8e4e56fab7480a3defc11b2ac3856e27891bbe2" alt="在这里插入图片描述"
仅当"email"字段的值满足特定模式时才被选择,这个模式是以"@myemail.com"结尾的,而"%"符号表示可以有零个或多个字符。
SELECT username FROM customers WHERE email LIKE '%@myemail.com';
data:image/s3,"s3://crabby-images/02a81/02a81d3be4f8b70412c1a74f8ec470a30b10254a" alt="在这里插入图片描述"
利用选择的数据创建一个新表
CREATE TABLE usernames AS SELECT username FROM customers WHERE email LIKE '%@myemail.com';
data:image/s3,"s3://crabby-images/78c29/78c29c235b40fac0c68dd1fb049465a02739b822" alt="在这里插入图片描述"
5. 排序
选择的数据将按照"lastname"字段进行降序排列
SELECT firstname, lastname
FROM customers
ORDER BY lastname DESC;
data:image/s3,"s3://crabby-images/30c83/30c835076672b3fb39680df5ba572e19bed71ebc" alt="在这里插入图片描述"
返回的结果将会包含每个客户的完整姓名、邮箱地址以及密码的长度,并且按照密码长度从短到长进行排序。
SELECT firstname || ' ' || lastname fullname, email, LENGTH(password) passwordlength
FROM customers
ORDER BY passwordlength;
data:image/s3,"s3://crabby-images/9adc8/9adc8ec0c8c064c6bcd546bf6da934d60c4c5491" alt="在这里插入图片描述"
选择 password 长度小于9的数据
SELECT firstname || ' ' || lastname fullname, email, LENGTH(password) passwordlength
FROM customers
WHERE LENGTH(password) < 9
ORDER BY passwordlength;
data:image/s3,"s3://crabby-images/75076/75076522f75c30012ad0a7dc7f61edc0c7a5fd0e" alt="在这里插入图片描述"
6. 删除
使用RETURNING关键字,返回受影响的行。
DELETE FROM customers
WHERE customer_id = 1
RETURNING *;
data:image/s3,"s3://crabby-images/6986d/6986d7dbfdc359e484321a4e8d3d9b18c6ed235b" alt="在这里插入图片描述"
从"customers"表中删除"username"字段不等于’nkidman’的行
DELETE FROM customers
WHERE username <> 'nkidman'
RETURNING *;
data:image/s3,"s3://crabby-images/96226/9622652f1bb20e023f32d93727b099d19a3803b8" alt="在这里插入图片描述"
从"customers"表中删除所有行。
DELETE FROM customers
RETURNING *;
data:image/s3,"s3://crabby-images/fdf15/fdf15a6dd2fce3df57a9744badd4867e0f43e4f0" alt="在这里插入图片描述"
7. 创建只读用户
该用户的有效期截止到’2024-02-02’。
CREATE USER readitralph
WITH PASSWORD 'password'
VALID UNTIL '2024-02-02';
授予名为"readitralph"的用户对数据库中所有数据的读取权限。
GRANT pg_read_all_data TO readitralph;