CREATE DATABASE
- CREATE DATABASE
- creates a new database
CREATE DATABASE GameDB;
data:image/s3,"s3://crabby-images/d36f7/d36f715e20021bf660c30af533a7b149e1f45c1c" alt=""
- CREATE TABLE
- creates a new table
- defines column and constraints
CREATE TABLE accounts(
accountId INTEGER NOT NULL,
accountName VARCHAR(10) NOT NULL,
coins INTEGER DEFAULT 0,
createdTime DATETIME
);
data:image/s3,"s3://crabby-images/841b7/841b753ceea5d9909ea6d089752943e1b6b11703" alt=""
data:image/s3,"s3://crabby-images/02416/024166c5dd49fe09a4f9a4e1ccc4097400c3a160" alt=""
data:image/s3,"s3://crabby-images/617bf/617bfd280f019ba53f8b9036191eeb54e3ad9eda" alt=""
- DROP TABLE
- removes the table
DROP TABLE accounts;
- ALTER TABLE
- changes the table
- ADD: add new column
ALTER TABLE accounts
ADD lastEnterTime DATETIME;
data:image/s3,"s3://crabby-images/14d0a/14d0a4d46a27c79f67a7c4ab9b38d5d18e780f90" alt=""
- DROP COLUMN
- removes the column
ALTER TABLE accounts
DROP COLUMN lastEnterTime;
data:image/s3,"s3://crabby-images/49d3c/49d3cd2deda6e25057e5058661d280bab2a3c9b9" alt=""
- ALTER COLUMN
- changes the column
ALTER TABLE accounts
ALTER COLUMN accountName VARCHAR(20) NOT NULL;
data:image/s3,"s3://crabby-images/29a39/29a392a49766b4b9f7dcb7e8197edf83c2d975fd" alt=""
- PRIMARY KEY
- assigns the column to primary key
ALTER TABLE accounts
ADD PRIMARY KEY (accountId);
data:image/s3,"s3://crabby-images/75aef/75aef5cf823d3de846a78a325f469889b0acd4fc" alt=""
- You can assign primary key in GUI
data:image/s3,"s3://crabby-images/bfe33/bfe33425c946bbac4add31a3ffbe253c34038a4e" alt=""
data:image/s3,"s3://crabby-images/d7087/d7087b2af6be7aa782a5feebc4745e5ff385c5dd" alt=""
-
PRIMARY KEY
improves the performance of database
data:image/s3,"s3://crabby-images/efec8/efec8fbed9245af31013fd9b0a5d85a83ab32a7e" alt=""
data:image/s3,"s3://crabby-images/a86cf/a86cf5f56d85b3ae0c865e6b142cd400b9a38830" alt=""
- CONSTRAINT
- defines the name of constraint
- it makes easier to remove the contraint
ALTER TABLE accounts
ADD CONSTRAINT PK_Account PRIMARY KEY(accountId);
ALTER TABLE accounts
DROP CONSTRAINT PK_Account;
INDEX
-
for regulation, you can use
INDEX
to index data - Clustered
- data is saved by order(ex. alpabet, number, etc.)
- normally, it is primary key
- Non-Clustered
- data is saved by index
- CREATE INDEX
- makes new non-clustered index
CREATE INDEX i1 ON accounts(accountName);
data:image/s3,"s3://crabby-images/0886d/0886d0e19d63a058ae04fc6575a52384af7c44b3" alt=""
- You can make index by several values
CREATE UNIQUE INDEX i3 ON accounts(accountName, coins);
data:image/s3,"s3://crabby-images/4dbab/4dbab2b75eae7907b9fdaf0253ba590e90731696" alt=""
- UNIQUE
- defines the column has dintinct values
CREATE UNIQUE INDEX i2 ON accounts(accountName);
data:image/s3,"s3://crabby-images/0ee54/0ee5476ad4f7b28756d0adb34e36933191ec533d" alt=""
- DROP
- removes the index
DROP INDEX accounts.i1;
data:image/s3,"s3://crabby-images/9b330/9b3301fce041c2cbf2d9e4f82db21ca879f2604c" alt=""
- CLUSTERED
- makes clustered index when there is not primary key in table
CREATE CLUSTERED INDEX i4 ON accounts(accountName);
data:image/s3,"s3://crabby-images/98c45/98c4514f33611b8c5125c2f20dcfa3e2c60679a1" alt=""
JOIN
- JOIN
- join all elements of each table
SELECT *
FROM testA
CROSS JOIN testB;
data:image/s3,"s3://crabby-images/fb0b6/fb0b6a71a58e860806b4f9e30a118cbf9783351a" alt=""
TRANSACTION
- TRANSACTION
- groups process into units
- You should write
ROLLBACK
orCOMMIT
at the end
BEGIN TRAN;
INSERT INTO accounts VALUES(2, 'Hanna2', 100, GETUTCDATE());
data:image/s3,"s3://crabby-images/943dc/943dcf08255a83c9237d6cab4e78231847299b9d" alt=""
- ROLLBACK
- returns the process to before status
ROLLBACK;
data:image/s3,"s3://crabby-images/935fb/935fb3875ed761333b522bcac78a73b521d581ac" alt=""
- COMMIT
- comfirm the process
BEGIN TRAN;
INSERT INTO accounts VALUES(2, 'Hanna2', 100, GETUTCDATE());
COMMIT;
data:image/s3,"s3://crabby-images/c636a/c636ae11f2b6e468f6f0f6cf05257bd3d1bc696c" alt=""
- LOCK
- there is not
COMMIT
orROLLBACK
inTRAN
, the process is in lock
- there is not
TRY - CATCH
- TRY - CATCH
- when the process has error or exception, tries
CATCH
- if there is not error or exceiption in
TRY
, then process the process inTRY
- when the process has error or exception, tries
-
@TRANCOUNT
- number of transaction
BEGIN TRY
BEGIN TRAN;
INSERT INTO accounts VALUES (1, 'Hanna', 100, GETUTCDATE());;
INSERT INTO accounts VALUES (2, 'Hanna2', 100, GETUTCDATE());;
COMMIT;
END TRY
BEGIN CATCH
IF @@TRANCOUNT>0
ROLLBACK
PRINT('ROLLBACK')
END CATCH
data:image/s3,"s3://crabby-images/3373c/3373c19673bb00726886479ed0ce8253d60d8008" alt=""
BEGIN TRY
BEGIN TRAN;
INSERT INTO accounts VALUES (1, 'Hanna', 100, GETUTCDATE());;
INSERT INTO accounts VALUES (3, 'Hanna3', 100, GETUTCDATE());;
COMMIT;
END TRY
BEGIN CATCH
IF @@TRANCOUNT>0
ROLLBACK
PRINT('ROLLBACK')
END CATCH
data:image/s3,"s3://crabby-images/85583/85583fc179e3fd4f4e85a53ee29657ac82681dd2" alt=""