Mysql常用命令总结上篇

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降序

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190117A163QY00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

同媒体快讯

扫码关注云+社区

领取腾讯云代金券