Oracle、MySQL 和 PostgreSQL 是当前最常用的三种关系型数据库管理系统。尽管它们在具体的语法细节上有所不同,但是它们都支持一些基本的 SQL 语法。以下是一些在 Oracle、MySQL 和 PostgreSQL 中通用的 100 条 SQL 语法:
- 创建/删除数据库表
 
-- Oracle, MySQL, PostgreSQL
CREATE TABLE users (
    id INT PRIMARY KEY,
    name VARCHAR(100),
    email VARCHAR(100)
);
 
-- Oracle, MySQL, PostgreSQL
DROP TABLE users;
- 插入数据
 
-- Oracle, MySQL, PostgreSQL
INSERT INTO users (id, name, email) VALUES (1, 'John Doe', 'john@example.com');
- 更新数据
 
-- Oracle, MySQL, PostgreSQL
UPDATE users SET name = 'Jane Doe' WHERE id = 1;
- 删除数据
 
-- Oracle, MySQL, PostgreSQL
DELETE FROM users WHERE id = 1;
- 查询数据
 
-- Oracle, MySQL, PostgreSQL
SELECT * FROM users;
- 创建/删除索引
 
-- Oracle, MySQL, PostgreSQL
CREATE INDEX idx_users_name ON users(name);
 
-- Oracle, MySQL, PostgreSQL
DROP INDEX idx_users_name;
- 创建/删除视图
 
-- Oracle, MySQL, PostgreSQL
CREATE VIEW user_view AS SELECT id, name FROM users;
 
-- Oracle, MySQL, PostgreSQL
DROP VIEW user_view;
- 创建/删除存储过程
 
-- Oracle
CREATE OR REPLACE PROCEDURE add_user(p_id IN NUMBER, p_name IN VARCHAR2, p_email IN VARCHAR2) AS BEGIN
    INSERT INTO users (id, name, email) VALUES (p_id, p_name, p_email);
END;
/
 
-- MySQL, PostgreSQL
CREATE PROCEDURE add_user(IN p_id INT, IN p_name VARCHAR(100), IN p_email VARCHAR(100)) BEGIN
    INSERT INTO users (id, name, email) VALUES (p_id, p_name, p_email);
END;
 
-- Oracle, MySQL, PostgreSQL
DROP PROCEDURE add_user;
- 事务处理
 
-- Oracle, MySQL, PostgreSQL
START TRANSACTION;
INSERT INTO users (id, name, email) VALUES (1, 'John Doe', 'john@example.com');
UPDATE users SET name = 'Jane Doe' WHERE id = 1;
COMMIT;
- 创建/删除触发器
 
-- Oracle, MySQL, PostgreSQL
CREATE TRIGGER before_user_insert
BEFORE INSERT ON users
FOR EACH ROW
BEGIN
    -- 在这里写入触发器逻辑
END;
 
-- Oracle, MySQL, PostgreSQL
DROP TRIGGER before_user_insert;
这些示例展示了在三种数据库中创建表、索引、视图、存储过程、事务处理和触发器的基本语法。虽然具体的语法细节在数据库间存在差异,