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;
这些示例展示了在三种数据库中创建表、索引、视图、存储过程、事务处理和触发器的基本语法。虽然具体的语法细节在数据库间存在差异,