/*创建表*/
CREATE TABLE table_name(
name1 type1 PRIMARY KEY,--主键
name2 type2,
name3 type3
);
/*插入数据*/
INSERT
INTO table_name
VALUES (value1-1,value1-2,value1-3),
(value2-1,value2-2,value2-3),
(value3-1,value3-2,value3-3);
/*为表增加一个字段*/
ALTER TABLE table_name ADD name4 type4;
--增加了字段之后,原来的数据并没有该字段的值,这个咋整???
/*删除数据*/
DELETE
FROM table_name
WHERE column_name=name2;
--删除姓名是name2的所有信息
/*更新数据*/
UPDATE table_name
SET value1-2=value0;
--WHERE column_name=name1,只更新name1中的值
--同时也可以增加WHERE子句来限制更新的范围
/*查询数据*/
SELECT value1-2
FROM table_name;
--WHERE column_name=value
--可以通过WHERE字句来限制查询的范围
/*创建索引*/
--普通索引
CREATE INDEX index_name ON table_name(column_name);
--非空索引
CREATE UNIQUE INDEX index_name ON table_name(column_name);
--主键索引
CREATE PRIMARY KEY INDEX index_name ON table_name(column_name);
/*使用ALTER TABLE语句创建索引*/
ALTER TABLE table_name ADD INDEX index_name(column_list);
ALTER TABLE table_name ADD UNIQUE (column_list);
ALTER TABLE table_name ADD PRIMARY KEY (column_list);
/*删除索引*/
DROP INDEX index_name ON table_name;
ALTER TABLE table_name DROP index index_name;
ALTER TABLE table_name DROP PRIMARY KEY;
/*创建外键*/
--在创建表的时候同时创建
CREATE TABLE table1(
code int PRIMARY KEY,
name1 int,
name2 int
);
CREATE TABLE table2(
num int PRIMARY KEY,
name3 int,
name4 int FOREIGN KEY REFERENCES table1(code)--创建了一个与table1中的code主键对应的外键
);
/*增加外键约束*/
ALTER TABLE fk_table_name ADD CONSTRAINT fk_name FOREIGN KEY REFERENCES zhu_table_name(column_name)
/*删除外键*/
ALTER TABLE fk_table_name DROP CONSTRAINT fk_name
--fk_table_name:外键所在的表名,fk_name:外键名
--如果在执行含有创建外键的语句时出现错误:"外键引用了无效的编号",这说明外键依赖的主键所在的表还未创建,所以必须调动它们创建的顺序。
--如果两个表的两个外键相互依赖,最好不要把创建外键的语句放在创建表的内部,因为这会产生矛盾,此时最好在创建两张表之后,再在外边使用外键约束来创建外键
/*创建视图*/
--视图的其他语句,例如"增删改查、约束、WHERE"字句的使用都跟创建一个TABLE的使用方式是一样的,只需要把table_name换成相应的view_name即可
CREATE VIEW view_name(view_column1,view_column2)
AS
SELECT zhu_column1,zhu_column2
FROM table_name
--如果执行该语句出现了错误:”CREATE VIEW必须是批处理中仅有的语句“,可以在创建视图的语句前后加上"GO"语句
GO
CREATE VIEW view_name(view_column1,view_column2)
AS
SELECT zhu_column1,zhu_column2
FROM table_name
GO