SQL语句的基本知识
2017-05-29 10:32
155 查看
SQL语句分类
1.DDL: 数据定义语言,用来定义数据库对象:创建库,表,列等等。2.DML: 数据操作语言,用来定义数据库记录(数据): 增 删 改: 表记录
3.DCL: 数据控制语言,用来定义访问权限和安全级别
4.DQL(*重要*): 数据查询语言,用来查询记录(数据)
ddl:数据库或表的结构操作(*)
dml:对表的记录进行更新(增、删、改)(*)
dql:对表的记录的查询(*,难点)
dcl:对用户的创建,及授权!
DDL
创建数据库 CREATE DATABASE [IF NOT EXISTS] mydb1 [CHARSET=utf8]删除数据库:DROP DATABASE [IF EXISTS] mydb1
修改数据库编码:ALTER DATABASE mydb1 CHARACTER SET utf8
创建表:
CREATE TABLE [IF NOT EXISTS] 表名 ( 列名 列类型, 列名 列类型, ... 列名 列类型 );
查看当前数据库中所有表名称:SHOW TABLES;
查看指定表的创建语句:SHOW CREATE TABLE 表名(了解);
查看表结构:DESC 表名;
删除表:DROP TABLE 表名;
修改表:前缀:ALTER TABLE 表名
修改之添加列:
ALTER TABLE 表名 ADD ( 列名 列类型, 列名 列类型, ... );
修改之修改列类型(如果被修改的列已存在数据,那么新的类型可能会影响到已存在数据):
ALTER TABLE 表名 MODIFY 列名 列类型;
修改之修改列名:
ALTER TABLE 表名 CHANGE 原列名 新列名 列类型;
修改之删除列:
ALTER TABLE 表名 DROP 列名;
修改表名称:
ALTER TABLE 原表名 RENAME TO 新表名;
总结
alter table 表名 add ( 列名 列类型, 列名 列类型, ... 列名 列类型 )
alter table 表名 modify 列名 列新的类型
alter table 表名 rename to 新名
DML
(数据操作语言,它是对表记录的操作(增、删、改)在数据库中所有的字符串类型,必须使用单引,不能使用双引!
日期类型也要使用单引!
1.插入数据
INTERT INTO 表名 (列名1,列名2, ...) VALUES(列值1, 列值2, ...);
在表名后给出要插入的列名,其他没有指定的列等同与插入null值。所以插入记录总是插入一行,不可能是半行。
在VALUES后给出列值,值的顺序和个数必须与前面指定的列对应
INTERT INTO 表名 VALUES(列值1, 列值2)
没有给出要插入的列,那么表示插入所有列。
值的个数必须是该表列的个数。
值的顺序,必须与表创建时给出的列的顺序相同。
/*插入所有列*/ INSERT INTO stu( number, name, age, gender ) VALUES( ‘1', 'zhangSan', 28, 'male' );
/*插入部分列,没有指定的列默认为NULL值*/ INSERT INTO stu( number, name ) VALUES( 'ITCAST_0002', 'liSi' )
/*不给出插入列,那么默认为插入所有列!值的顺序要与创建表时列的顺序相同*/ INSERT INTO stu VALUES( '1', 'wangWu', 82, 'female' );
2.修改数据
UPDATE 表名 SET 列名1=列值1, 列名2=列值2, ... [WHERE 条件]
条件(条件可选的):
条件必须是一个boolean类型的值或表达式:
运算符:=、!=、<>、>、<、>=、<=、BETWEEN…AND、IN(…)、IS NULL、NOT、OR、AND
UPDATE person SET gender='男', age=age+1 WHERE sid='1';
WHERE age >= 18 AND age <= 80 WHERE age BETWEEN 18 AND 80 WHERE name='zhangSan' OR name='liSi' WHERE name IN ('zhangSan', 'liSi') WHERE age IS NULL //不能使用等号 WHERE age IS NOT NULL
3.删除数据
/*删除某条数据,如果不加where,则删除整个表的数据*/ DELETE FROM 表名 [WHERE 条件]; /*或者*/ TRUNCATE TABLE 表名; /*TRUNCATE是DDL语句,它是先删除drop该表,再create该表。而且无法回滚!!!*/
DQL
数据查询语言只查询,不会修改数据库表记录!
字段(列)控制
1) 查询所有列
SELECT * FROM 表名;
SELECT * FROM people;
–> 其中“*”表示查询所有列
2) 查询指定列
SELECT 列1 [, 列2, … 列N] FROM 表名;
SELECT ID, name, salary FROM people;
3) 完全重复的记录只一次
当查询结果中的多行记录一模一样时,只显示一行。一般查询所有列时很少会有这种情况,但只查询一列(或几列)时,这总可能就大了!
SELECT DISTINCT * [列1 , 列2, … 列N] FROM 表名;
SELECT DISTINCT sal FROM emp; --> 保查询员工表的工资,如果存在相同的工资只显示一次!
相关文章推荐
- 自己总结的一些SQL语句的基本知识
- SQL基本语句及基础知识
- oracle学习笔记(一)------oracle基础知识和基本sql语句
- sql命令语句基本知识学习记录(1)
- [置顶] Android,java,php开发最基本的知识,mysql sqlite数据库的增删改查代理,sql语句
- sql 语句的基本知识,比较杂。
- 复习Oracle数据库知识(一)——基本概念和sql简单语句
- 关于SQL SERVER 2000的一些基本知识(1)——简单的SQL语句
- SQL语句的一些基本知识
- SQL语句一二三之SQL基本语句
- oracle数据库的sql基本语句
- SQL语句的基本语法
- SQL语句的基本语法
- 动态sql语句基本语法
- SQL基本语句小结
- SQL备忘-基本控制语句复习及@@ROWCOUNT陷阱纪实
- SQL语句基本的用法
- 动态sql语句基本语法
- 动态sql语句基本语法
- SQL语句的基本语法