insert语句(插入)
insert语句比较简单, 其语法为:
insert into 表名 (属性1, 属性2, 属性3, ...) values (值1, 值2, 值3, ...);
或者
insert into 表名 values (值1, 值2, 值3, ...);
两者的区别是第一种在插入时, 每个值和属性一一对应插入, 第二种插入则将每个值依次插入到表中的每个属性上(从第一个到最后一个), 如果值的数量小于属性的数量, 那么后面的属性将会被空闲
SELECT语句(查询)
首先看看MySQL SELECT语句的官方语法
SELECT
[ALL | DISTINCT | DISTINCTROW ]
[HIGH_PRIORITY]
[STRAIGHT_JOIN]
[SQL_SMALL_RESULT] [SQL_BIG_RESULT] [SQL_BUFFER_RESULT]
[SQL_CACHE | SQL_NO_CACHE] [SQL_CALC_FOUND_ROWS]
SELECT_expr [, SELECT_expr ...]
[FROM table_references
[PARTITION partition_list]
[WHERE where_condition]
[GROUP BY {col_name | expr | position}
[ASC | DESC], ... [WITH ROLLUP]]
[HAVING where_condition]
[ORDER BY {col_name | expr | position}
[ASC | DESC], ...]
[LIMIT {[offset,] row_count | row_count OFFSET offset}]
[PROCEDURE procedure_name(argument_list)]
[INTO OUTFILE 'file_name'
[CHARACTER SET charset_name]
export_options
| INTO DUMPFILE 'file_name'
| INTO var_name [, var_name]]
[FOR UPDATE | LOCK IN SHARE MODE]]
归纳SELECT的用法, 其语法结构为
SELECT 属性列表 FROM 表名 WHERE 条件语句
- 属性列表可以是任意多个, 使用***表示选择全部属性
- 表名为单表或者多表联合的结果
- 在条件语句中,可以对查询结果进行筛选,排序等操作
SELECT的更名运算
对属性重命名
SELECT oldname1 AS newname1, oldname2 AS newname2 FROM table;
将会下显示结果中使用新的名字代替旧的名字, 其中AS不是必须的, 可以直接写成oldname newname
对表重命名:
SELECT T.ID, T.name FROM user AS T;
对选择结果排序使用ORDER BY 属性名1 排序方式(ASC|DESC), 属性名2 排序方式(ASC|DESC)
SELECT * FROM student ORDER BY score DESC, name ASC;
表示对student按分数降序排序, 按名字升序排序
SELECT查询数据时的默认参数为 ALL, 即,如果查询结果中有重复的元祖, 默认会把全部元组输出, 如果不想有重复元组输出, 在SELECT 后面加一个关键词distinct就可以了
SELECT DISTINCT sex FROM student;
UPDATE语句(修改)
UPDATE 表名 SET 属性名1=新值, 属性名2=新值 WHERE 约束条件
DELETE语句(删除)
DELETE FROM 表名 WHERE 条件
如果DELETE语句没有加条件, 将会删除表中的所有数据