创建表
语法
CREATE TABLE <表名>(<列名> <数据类型>[列级完整性约束条件]
[,<列名> <数据类型>[列级完整性约束条件]]…);
列级完整性约束条件有NULL[可为空]、NOT NULL[不为空]、UNIQUE[唯一],可以组合使用,但是不能重复和对立关系同时存在。
示例
-- 创建学生表
CREATE TABLE Student
(
Id INT NOT NULL UNIQUE PRIMARY KEY,
Name VARCHAR(20) NOT NULL,
Age INT NULL,
Gender VARCHAR(4) NULL
);
删除表
语法
DROP TABLE <表名>;
示例
-- 删除学生表
DROP TABLE Student;
清空表
语法
TRUNCATE TABLE <表名>;
示例
-- 删除学生表
TRUNCATE TABLE Student;
修改表
语法
-- 添加列
ALERT TABLE <表名> [ADD <新列名> <数据类型>[列级完整性约束条件]]
-- 删除列
ALERT TABLE <表名> [DROP COLUMN <列名>]
-- 修改列
ALERT TABLE <表名> [MODIFY COLUMN <列名> <数据类型> [列级完整性约束条件]]
示例
-- 添加学生表`Phone`列
ALERT TABLE Student ADD Phone VARCHAR(15) NULL;
-- 删除学生表`Phone`列
ALERT TABLE Student DROP COLUMN Phone;
-- 修改学生表`Phone`列
ALERT TABLE Student MODIFY Phone VARCHAR(13) NULL;
SQL查询语句
语法
SELECT [ALL|DISTINCT] <目标列表达式>[,<目标列表达式>]…
FROM <表名或视图名>[,<表名或视图名>]…
[WHERE <条件表达式>]
[GROUP BY <列名> [HAVING <条件表达式>]]
[ORDER BY <列名> [ASC|DESC]…]
SQL查询语句的顺序:SELECT、FROM、WHERE、GROUP BY、HAVING、ORDER BY。SELECT、FROM是必须的,HAVING子句只能与GROUP BY搭配使用。
示例
SELECT * FROM Student
WHERE Id>10
GROUP BY Age HAVING AVG(Age) > 20
ORDER BY Id DESC
SQL插入语句
语法
-- 插入不存在的数据
INSERT INTO <表名> [(字段名[,字段名]…)] VALUES (常量[,常量]…);
-- 将查询的数据插入到数据表中
INSERT INTO <表名> [(字段名[,字段名]…)] SELECT 查询语句;
示例
-- 插入不存在的数据
INSERT INTO Student (Name,Age,Gender) VALUES ('Andy',30,'女');
-- 将查询的数据插入到数据表中
INSERT INTO Student (Name,Age,Gender)
SELECT Name,Age,Gender FROM Student_T WHERE Id >10;
SQL更新语句
语法
UPDATE <表名> SET 列名=值表达式[,列名=值表达式…]
[WHERE 条件表达式]
示例
-- 将Id在(10,100)的Age加1
UPDATE Student SET Age= Age+1 WHERE Id>10 AND Id<100
SQL删除语句
语法
DELETE FROM <表名> [WHERE 条件表达式]
示例
-- 删除Id小于10的数据记录
DELETE FROM Student WHERE Id<10;
创建索引
语法
CREATE [UNIQUE] [CLUSTER] INDEX <索引名> ON <表名>(<列名>[<次序>][,<列名>[<次序>]]…);
UNIQUE:表明此索引的每一个索引值只对应唯一的数据记录
CLUSTER:表明建立的索引是聚集索引
次序:可选ASC(升序)或DESC(降序),默认ASC
示例
-- 建立学生表索引:单一字段Id索引倒序
CREATE UNIQUE INDEX INDEX_SId ON Student (Id DESC);
-- 建立学生表索引:多个字段Id、Name索引倒序
CREATE UNIQUE INDEX INDEX_SId_SName ON Student (Id DESC,Name DESC);
删除索引
语法
DROP INDEX <索引名>;
示例
-- 删除学生表索引 INDEX_SId
DROP INDEX INDEX_SId;
创建视图
语法
CREATE VIEW <视图名>
AS SELECT 查询子句
[WITH CHECK OPTION]
查询子句:子查询可以是任何SELECT语句,但是常不允许含有ORDER BY子句和DISTINCT短语;
WITH CHECK OPTION:表示对UPDATE、INSERT、DELETE操作时要保证更新。
示例
CREATE VIEW VIEW_Stu_Man
AS SELECT * FROM Student WHERE Gender = '男'
WITH CHECK OPTION
删除视图
语法
DROP VIEW <视图名>;
示例
DROP VIEW VIEW_Stu_Man;
SQL的访问控制
访问控制是控制用户的数据存储权限,由DBA来决定。
SQL标准语句包括SELECT、INSERT、UPDATE和DELETE
语法
-- 1.授权
GRANT <权限>[,<权限>]…
[ON <对象类型> <对象名>]
TO <用户>[,<用户>]…
[WITH GRANT OPTION]
-- 2.收回授权
REVOKE <权限>[,<权限>]…
[ON <对象类型> <对象名>]
FROM <用户>[,<用户>]…
WITH GRANT OPTION:若指定此子句,表示该用户可以将权限赋给其他用户
示例
-- 授权
GRANT SELECT,INSERT,UPDATE ON TABLE TO USER_Admin WITH GRANT OPTION
-- 收回授权
REVOKE SELECT,INSERT,UPDATE ON TABLE FROM USER_Admin
相关推荐
达梦8数据库操作语法
数据库基础 sql 语句 语法 编程 ,数据库基础 sql 语句 语法 编程 。
SQL基本语句与使用。数据查询(操作符及函数控制),数据库更新(表),数据定义(索引,数据控制)等。
关于Oracle数据库Sql语句详解大全的PPT。适合入门级和教学级。
数据库常用语句,数据库常用SQL语法!希望对大家有帮助。
sql语句的总结sql语句的总结sql语句的总结sql语句的总结sql语句的总结sql语句的总结sql语句的总结sql语句的总结sql语句的总结
动态sql语句基本语法 1 :普通SQL语句可以用Exec执行 例: Select * from tableName Exec('select * from tableName') Exec sp_executesql N'select * from tableName' -- 请注意字符串前一定要加N 2:字段名,...
SQL_ServerDB2数据库SQL语句比较
SQL语句大全(很全)sql语句用法,对于mysql,oracle,sqlserver 数据库的sql语法,各种语句优化.
结构化查询语言SQL(STRUCTURED QUERY LANGUAGE)是最重要的关系数据库操作语言,本文档包括sql语句相关语法和例子,总结版
本文描述了SQL常用的所有语句,编写数据库程序时非常好的参考手册。
相信你一定会用Pl/sql Developer、Toad等工具去看一个语句的执行计划,不过你可能对Rule、Choose、First rows、All rows这几项有疑问,因为我当初也是这样的,那时我也疑惑为什么选了以上的不同的项,执行计划就变了?
经典SQL语句,sql备份数据库,sql基本入门的语法。
本资源主要有以下类容 SQL语句语法: 数据定义语句、数据操作语句、MySQL实用工具语句、MySQL事务处理和锁定语句、数据库管理语句、复制语句、用于预处理语句的SQL语法
Transact-SQL语句 语法大全2008-01-17 10:33语句 ----功能 --数据操作 SELECT --从数据库表中检索数据行和列 INSERT --向数据库表添加新数据行 DELETE --从数据库表中删除数据行 UPDATE --更新数据库表...
sql MySQL 查询,官方原版文档 13.1. 数据定义语句 13.1.1. ALTER DATABASE语法 13.1.2. ALTER TABLE语法 ...13.6.1. 用于控制主服务器的SQL语句 13.6.2. 用于控制从服务器的SQL语句 13.7. 用于预处理语句的SQL语法
包含Access数据库SQL语句操作,使用SQL操作桌面数据库的不错的手册
SQL语句教程 SQL指令 表格处理 SQL语法 无论您是一位 SQL 的新手,或是一位只是需要对 SQL 复习一下的资料仓储业界老将, 您就来对地方了。这个 SQL 教材网站列出常用的 SQL 指令。这个网站包含以下几个部分: ...