一些最重要的 SQL 命令
SELECT - 从数据库中提取数据
1、select语法
select column_name,column_name drom table_name

select * from table_name(选取所有列)
2、select distinct用于返回唯一不同的值
语法:select distinct column_name,column_name form table_name
3、where字句用于过滤记录
语法:select column_name,column_name form table_name where column_name operator value;


UPDATE - 更新数据库中的数据
update table_name set column1=value1,column2=value2,... where some_column=some_value;(where子句规定哪条记录或者哪条记录需要更新。如果忽略了,所有的积都会被更新)


DELETE - 从数据库中删除数据
语法:delect from table_name where some_column=some_value;


INSERT INTO - 向数据库中插入新数据
有两种编写形式:
1、insert into table_name values(value1,value2,value3,...);
2、insert into table_name(column1,column2,column3,...) values(value1,value2,value3,...);


CREATE DATABASE - 创建新数据库
CREATE DATABASE dbname;




ALTER DATABASE - 修改数据库

CREATE TABLE - 创建新表
SQL CREATE TABLE 语法


CREATE TABLE table_name
 (
 column_name1 data_type(size),
 column_name2 data_type(size),
 column_name3 data_type(size),
 ....
 );


column_name 参数规定表中列的名称。


data_type 参数规定列的数据类型(例如 varchar、integer、decimal、date 等等)。


size 参数规定表中列的最大长度。


在 SQL 中,我们有如下约束:


NOT NULL - 指示某列不能存储 NULL 值。
UNIQUE - 保证某列的每行必须有唯一的值。
PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。
FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。
CHECK - 保证列中的值符合指定的条件。
DEFAULT - 规定没有给列赋值时的默认值。


ALTER TABLE - 变更(改变)数据库表
DROP TABLE - 删除表
CREATE INDEX - 创建索引(搜索键)
SQL CREATE INDEX 语法


在表上创建一个简单的索引。允许使用重复的值:


CREATE INDEX index_name
ON table_name (column_name)
SQL CREATE UNIQUE INDEX 语法


在表上创建一个唯一的索引。不允许使用重复的值:唯一的索引意味着两个行不能拥有相同的索引值。Creates a unique index on a table. Duplicate values are not allowed:


CREATE UNIQUE INDEX index_name
ON table_name (column_name)


DROP INDEX - 删除索引


order by关键字
用于对结果集进行排序
语法:select column_name,column_name form table_name order by column_name,column_name ASC|DESC;


inner join在表中存在至少一个匹配时返回行
语法:select column_name(s) from table1 inner join table2 on table1.column_name=table2.column_name


SELECT INTO 语句从一个表复制数据,然后把数据插入到另一个新表中。
我们可以复制所有的列插入到新表中:


SELECT *
INTO newtable [IN externaldb]
FROM table1;
或者只复制希望的列插入到新表中:


SELECT column_name(s)
INTO newtable [IN externaldb]
FROM table1;


INSERT INTO SELECT 语句从一个表复制数据,然后把数据插入到一个已存在的表中。目标表中任何已存在的行都不会受影响。


SQL INSERT INTO SELECT 语法


我们可以从一个表中复制所有的列插入到另一个已存在的表中:


INSERT INTO table2
SELECT * FROM table1;
或者我们可以只复制希望的列插入到另一个已存在的表中:


INSERT INTO table2
(column_name(s))
SELECT column_name(s)
FROM table1;