SQL语句的基本知识

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. 字段(列)控制
    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;
 --> 保查询员工表的工资,如果存在相同的工资只显示一次!
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值