SQL AUTO_INCREMENT / IDENTITY

SQL AUTO_INCREMENT / IDENTITY

To auto-generate unique values (usually for primary keys), databases offer built-in features like AUTO_INCREMENT (MySQL), IDENTITY (SQL Server), and GENERATED AS IDENTITY (PostgreSQL, Oracle).

🔹 Basic Usage by DBMS

Copy

-- MySQL
CREATE TABLE employees (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(100)
);

-- SQL Server
CREATE TABLE employees (
  id INT IDENTITY(1,1) PRIMARY KEY, -- (start, increment)
  name VARCHAR(100)
);

-- PostgreSQL & Oracle (modern versions)
CREATE TABLE employees (
  id INT GENERATED ALWAYS AS IDENTITY PRIMARY KEY,
  name VARCHAR(100)
);

🔹 Insert Example

Copy

INSERT INTO employees (name) VALUES ('Alice');
-- No need to provide `id`; it auto-generates

🔹 Controlling Identity (Optional)

  • MySQL: You can set AUTO_INCREMENT = value to restart or offset.
  • SQL Server: Use DBCC CHECKIDENT to reseed identity values.
  • PostgreSQL: Use sequences behind the scenes (can ALTER SEQUENCE).
  • Oracle: Uses sequences automatically with IDENTITY.

🧠 Quick Recap

Key PointExplanation
PurposeAuto-generate unique IDs (usually for primary key)
MySQL SyntaxAUTO_INCREMENT
SQL ServerIDENTITY(start, increment)
PostgreSQL/OracleGENERATED AS IDENTITY
Insert SimplicityNo need to provide the ID during insert

💡 Use auto-increment/identity columns to simplify primary key management and ensure uniqueness without manual effort.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值