开发者社区> YuShiwen> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

mysql数据库基本操作(sql语句加注释)

简介: mysql数据库基本操作(sql语句加注释)
+关注继续查看

该博文与另一篇博文(有运行截图)相联系:mysql基本操作截图+sql语句+注释

即是另一篇博文的源sql语句

# ##############创建hero表并插入数据##########
DROP TABLE IF EXISTS `hero`;
CREATE TABLE `hero` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(20) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `sex` char(1) DEFAULT NULL,
  `price` int(11) DEFAULT NULL,
  `type_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8;

INSERT INTO `hero`
(`id`,`name`,`age`,`sex`,`price`,`type_id`) 
VALUES 
(1,'李白',18,'男',18888,2),
(2,'孙尚香',17,'女',6888,4),
(3,'韩信',15,'男',NULL,2),
(4,'小乔',5,'女',NULL,3),
(5,'西施',5,'女',13888,3),
(7,'张飞',1,'男',13888,5),
(8,'花木兰',1,'女',NULL,1),
(9,'虞姬',16,'女',13888,4),
(10,'凯',NULL,NULL,13888,1),
(11,'孙策',NULL,NULL,NULL,NULL),
(12,'曹操',30,'男',NULL,4),
(13,'孙膑',5,NULL,NULL,5);
# ##################创表插入数据完成##############


-- ——————————————————crud语法————————————————————
-- 增
INSERT INTO hero VALUES(14,'杨玉环',18,'女',13888,3);
INSERT INTO hero (name,price,type_id) VALUES('马可波罗',13888,4);
INSERT INTO hero 
VALUES
    (16,'露娜',18,'女',NULL,2),
    (17,'张良',20,'男',NULL,3);

-- 删
DELETE FROM hero WHERE`name`='张良';
DELETE FROM hero ;
DELETE FROM hero WHERE 1=1 ;
DELETE FROM hero WHERE TRUE ;

-- 改
UPDATE hero SET `name`='百里守约' WHERE `name`='马可波罗';

-- 查
SELECT * FROM hero ;
SELECT * FROM hero WHERE sex = '男' ;
SELECT name,id,price ,sex FROM hero WHERE sex = '男';

SELECT * FROM hero WHERE `name`='百里守约';
SELECT * FROM hero WHERE name='百里守约';
SELECT * FROM hero WHERE NAME='百里守约';


-- ——————————————常用查询——————————————-———--
-- 条件查询
SELECT * FROM hero WHERE age>5 AND age<20;
SELECT * FROM hero WHERE age BETWEEN 5 AND 20; 
SELECT * FROM hero WHERE age IN (5,16,17);

-- 聚合函数
-- MAX 与 MIN 最大最小
SELECT MIN(age) FROM hero ;
SELECT * FROM hero WHERE age = (SELECT MIN(age) FROM hero) ;
-- SUM函数
SELECT SUM(age) FROM hero;
-- COUNT 函数
SELECT COUNT(*) FROM hero;
-- AVG 函数
SELECT AVG(age) FROM hero WHERE sex = '男';

-- 排序查询
SELECT * FROM hero ORDER BY age;
SELECT * FROM hero ORDER BY age DESC;

-- 模糊查询
-- 查询姓名为三个字的英雄:(三个下划线)
SELECT * FROM hero WHERE `name` LIKE '___';
-- 查询姓李的英雄:
SELECT * FROM hero WHERE `name` LIKE '李%';
-- 查询姓名至少为三个字的英雄:
SELECT * FROM hero WHERE `name` LIKE '___%';

-- 分页查询
SELECT * FROM hero LIMIT 3,2 ;



# ################################新建type表 ,插入五条数据################################
-- 如果存在tpye表就删除
DROP TABLE IF EXISTS `tpye`;
-- 创建type表
CREATE TABLE `type` (
  `tid` int(11) NOT NULL AUTO_INCREMENT,
  `tname` varchar(20) DEFAULT NULL,
  `route` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`tid`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
-- 插入数据
INSERT INTO
`type`(`tid`,`tname`,`route`) 
VALUES 
(1,'战士','上单'),
(2,'刺客','打野'),
(3,'法师','中路'),
(4,'射手','下路'),
(5,'辅助','下路');

# ############################################建表操作完成####################################




-- ————————————多表操作————————————————————————
-- 内连接
-- 笛卡尔积  h与t是hero表与type表的别名
-- mysql“方言版”
SELECT * FROM hero h, type t ;
-- 标准版
SELECT * FROM hero h INNER JOIN type t ;
-- 从笛卡尔积中取出指定的行 (mysql“方言版”)
SELECT * FROM hero h, type t WHERE h.type_id = t.tid ;
-- 从笛卡尔积中取出指定的行 (标准版)
SELECT * FROM hero h INNER JOIN type t ON h.type_id = t.tid ;

# #########向type表中插入一行数据,方便观察##############
INSERT INTO type VALUES(6,'新插入的','方便外连接观察');
# ##############插入完毕#######################

-- 外连接
-- 左外连接
SELECT * FROM hero h LEFT JOIN type t ON h.type_id = t.tid;
-- 右外连接
SELECT * FROM hero h RIGHT JOIN type t ON h.type_id = t.tid;
-- 全外连接
SELECT * FROM hero h LEFT JOIN type t ON h.type_id = t.tid
UNION
SELECT * FROM hero h RIGHT JOIN type t ON h.type_id = t.tid;

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL数据库基本操作-DDL
MySQL数据库基本操作-DDL
7 0
mysql数据库-表的基本操作
mysql数据库-表的基本操作
50 0
【MySQL】MySQL对数据的基本操作
前两篇博客总结完了MySQL对数据的查询,包括基本查询和高级查询,我们终于结束了查询这一部分了,不过有一说一查询这一部分还是非常非常重要的,有了这部分的基础我们才能继续学习MySQL后面的知识,如果你还没有学习这部分那我建议你先去看一下,再回来继续学习。
23 0
Mysql常用sql语句(1)- 操作数据库
Mysql常用sql语句(1)- 操作数据库
30 0
MySQL基本命令操作及数据库基本概念(二)
1、数据库的基本概念 2、主流数据库介绍 3、关系型非关系型数据库介绍 4、Mysql 安装方法 5、Mysql 基本操作命令
24 0
数据库MySQL的基本操作
1.MySQL数据库的安装: CentOS6上mysql服务端和客户端的安装和启动: #使用yum安装mysql数据库的服务端和客户端 yum install -y mysql mysql-server #把mysql服务端加入开机自启动 chkconfig msyqld on #立即启动mysql...
656 0
+关注
YuShiwen
能够成就别人的人才能称得上是真英雄,愿我们彼此相互成就,成为那个真英雄! Java开发工程师,全栈工程师,努力想成为架构师的小萌新; 每周至少写一篇高质量文章,干货满满! 愿我的文章对读者有用,欢迎评论,一起进步! 如果期待更多我的知识分享,请关注我,一起成为那个了不起的人吧!
149
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载