DDL: 操作数据库、表、列等
掌握如何使用的关键字:CREATE(创建)、 ALTER(修改)、 DROP(废弃,也是删除的意思)
操作数据库
create database 数据库名; 创建数据库
create database 数据库名 character set gbk; 创建编码为gbk的数据库(默认utf8)
查询数据库
show databases; 显示所有的数据库
Show create database 数据库名; 显示某数据库创建时信息
修改数据库编码
alter database 数据库名 character set utf8; 修改数据库编码
drop database 数据库名; 删除某数据库
其他命令:
select database(); 显示当前正在使用的数据库
use 数据库名; 切换使用数据库
操作数据表
当前数据库中的所有表 Show tables;
查看表的字段信息(表结构) desc 表名;
给学生增加一个image列 alter table student add image blob;
修改住址列长度为100 Alter table student modify zhuzhi varchar(100);
删除image列 alter table student drop image;//一次只能删除一个列
表名改为stu rename table student to stu;
查看表格的创建细节 show create table stu;
修改表的编码为gbk alter table user character set gbk;
列名zhuzhi修改为address alter table user change zhuzhi address varchar(100);
删除表 drop table stu ;
DML: 是对表中的数据进行增、删、改的操作。不要与DDL混淆了。INSERT(添加) 、UPDATE(更新,修改)、 DELETE(删除)
注意:
在mysql中,字符串类型和日期类型都要用单引号括起来。'tom' '2015-09-04'空值:null
插入操作:INSERT
语法: insert into 表名(列名1,列名2 ...)VALUES (列值1,列值2...);
注意:列名与列值的类型、个数、顺序要一一对应。
可以把列名当做java中的形参,把列值当做实参。
值不要超出列定义的长度。
如果插入空值,请使用null
插入的日期和字符一样,都使用引号括起来。
修改操作 UPDATE
语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值
删除操作 DELETE
语法 : DELETE FROM 表名 【WHERE 列名=值】
删除表中所有记录 Delete from stu;
删除表中名字为陆超的记录 DELETE FROM stu WHERE name=’陆超’;
使用truncate删除表中记录 TRUNCATE TABLE stu;
DQL操作【非常重要,核心】DQL数据查询语言 (重要)
数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。查询返回的结果集是 一张虚拟表。
查询关键字:SELECT 语法
SELECT selection_list /*要查询的列名称*/
FROM table_list /*要查询的表名称*/
WHERE condition /*行条件*/
GROUP BY grouping_columns /*对结果分组*/
HAVING condition /*分组后的行条件*/
ORDER BY sorting_columns /*对结果排序*/
LIMIT offset_start, row_count /*结果限定*/
基础查询
查询所有所有数据 SELECT * FROM stu;
查询指定列 SELECT sid, sname, age FROM stu;
条件查询介绍:
条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:
? =、!=、、、>=;
? BETWEEN…AND;
? IN(set);
? IS NULL; IS NOT NULL
? AND;
? OR;
? NOT;
模糊查询: 当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字like。
通配符:
_ 任意一个字符
%:任意0~n个字符
'%宫%' '诸葛_'
查询姓名由4个字符构成的学生记录
SELECT * FROM stu WHERE name LIKE '____';
模糊查询必须使用LIKE关键字。其中 “_”匹配任意一个字符,4个“_”表示4个任意字符。
查询姓名由5个字符构成,并且第5个字符为“y”的学生记录
SELECT * FROM stu WHERE name LIKE '____y';
查询姓名以“诸葛”开头的学生记录
SELECT * FROM stu WHERE name LIKE '诸葛%';
其中“%”匹配0~n个任何字母。
查询姓名中第2个字母为“宫”的学生记
SELECT * FROM stu WHERE name LIKE '_宫%';
查询姓名中包含“皮”字符的学生记录
SELECT * FROM stu WHERE name LIKE '%a%';
字段控制查询
去除重复记录
去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。
当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:
SELECT DISTINCT sal FROM emp;
查看雇员的月薪与佣金之和
因为sal和comm两列的类型都是数值类型,所以可以做加运算。如果sal或comm中有一个字段不是数值类型,
那么会出错。
SELECT *,sal+comm FROM emp;
comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以计算结果可能会出现NULL。
下面使用了把NULL转换成数值0的函数IFNULL:
SELECT *,sal+IFNULL(comm,0) FROM emp;
给列名添加别名
在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total:
SELECT *, sal+IFNULL(comm,0) AS ‘总工资’ FROM emp;
给列起别名时,是可以省略AS关键字的:
SELECT *,sal+IFNULL(comm,0) ‘总工资’ FROM emp;
排序
order by 列名 asc(默认) 升序 /desc降序
领取专属 10元无门槛券
私享最新 技术干货