sql学习之基础(MySql)
--#创建一个数据库
create database excise01;
--#查看所有数据库
show databases;
--#查看刚建的数据库
show create database excise01;
--#建表
use excise01;
create table stu(
id int not null primary key auto_increment, --#not null-->非空,primary key-->主键,auto_increment-->自增,都是约束
name varchar(20) unique, --#unique-->唯一,不能重复(约束)
birthday date,
sal float
);
show tables; --#查看表
show create table stu; --#查看表中信息
--#修改表
alter table stu add age int; --# 新增一个age,类型为int
alter table stu change age new_age int; --#修改"age"为"new_age"
alter table stu drop new_age; --#删除列
alter table stu rename new_name; --#修改表名
--#删除表
drop table stu;
--#查看表结构
desc stu;
DML:
--#往stu表中插入一条记录
insert into stu (id,name,birthday,sal) values(1,'itcast',2011-09-23,8000.00);
--#查看记录
select * from stu;
--#修改记录
update stu set sal=10000.00
--#删除记录
delete from stu; --#删除表中的所有内容(表还在)
--#设置编码集,set方法只对当前窗口有效.
set character_set_client=gb2312;
set character_set_results=gb2312; --#创建数据sql脚本如下
use day01; CREATE TABLE grade (
id int(11) NOT NULL auto_increment PRIMARY KEY ,
name varchar(20) NOT NULL,
math double,
english double,
chinese double
); set character_set_client=gb2312;
set character_set_results=gb2312; insert into grade(name,math,english,chinese) values('赵一',67,45,78);
insert into grade(name,math,english,chinese) values('郭二',77,83,89);
insert into grade(name,math,english,chinese) values('张三',82,75,60);
insert into grade(name,math,english,chinese) values('李四',67,45,78);
insert into grade(name,math,english,chinese) values('王五',90,89,91);
insert into grade(name,math,english,chinese) values('马六',33,23,56);
insert into grade(name,math,english,chinese) values('冯七',69,34,47);
insert into grade(name,math,english,chinese) values('贾八',NULL,NULL,NULL);
--#查询语句
--#过滤表中重复数据
select distinct(math) from grade; --#distinct表示过滤重复数据
--#给每个学生的数学加10分
select math+10 from grade;
--#查询姓名为某个值的学生成绩
select * from grade where name='lisi';
--#统计每个学生的总分
select math+english+chinese as 总分 from grade;
--#查询英语分数在80-90之间的同学
select name, english from grade where english>=80 and english<=90;
select name, english from grade where english between 80 and 90;
select name, english from grade where english>=80 && english<=90;
--#查询数学分数为89,90,91的同学
select name, math from grade where math=89 or math=90 or math=91;
select name, math from grade where math in(89,90,91);
select name, math from grade where math=89 || math=90 || math=91;
--#查询所有姓李的学生(模糊查询,更多应用在数据的检索中)
--# '%李%'-->匹配所有有李字的
--# '%李'--> 匹配最后一个字是"李"的,百分号'%'匹配多个字符
--# '李_'--> 后边是一个下划线'_'的,只能查到李后边是一个字的
select * from grade where name like '李_';
select * from grade where name like '%李%';
select * from grade where name like '李%';
--# 对数学成绩排序后输出
select math from grade order by math; --#默认是升序排序
select math from grade order by math asc; --#(同上一行,升序排序是asc,不写默认就是asc) select math from grade order by math desc;
--#统计人数
--#用'*'来统计的话,可以把所有的统计全了,包括表中的null值.
--#如果按照某一项来统计,如:"math",这样,可能把其中值为'null'的统计不上,所以一般情况下都用*来统计.
select count(*) as 总人数 from grade;
select count(math) as 总人数 from grade; --#统计数学成绩大于90的学生有多少个
select count(*) as 人数 from grade where math>90;
--#统计一个班级数学总成绩
select sum(math) as 数学总成绩 from grade;
--#统计一个班各科的总成绩
select sum(math) as 数学总成绩, sum(english) as 英语总成绩,sum(chinese) as 语文总成绩 from grade;
--#统计一个班的语文,英语,数学的成绩总和(as可以省略)
select sum(math)+sum(english)+sum(chinese) as 所有成绩总和 from grade;
select sum(math+english+chinese) as 所有成绩总和 from grade;
--#统计一个班语文成绩平均分
select sum(chinese)/count(*) 语文平均成绩 from grade; --#(常用的)
select avg(chinese) 语文平均分 from grade; --#avg大多情况下不用,因为用avg统计的是按照本列统计的,如果有null值的话,统计不到,结果会比正常的大
--#求班级最高分和最低分
select max(math) 最高分, min(math) 最低分 from grade; -----------------------------字符函数-------------------------------------------
select char_length('abcdef'); --#字符串长度
select instr('abcdefghij','f'); --#查询后边字符所在位置 --#从字符串'helloworld'的第6个位置开始插入,插入的是'haha',替换后边几个位置,是1就是一个,0就是不替换
select insert('helloworld',6,1,'haha');
select substring('hello world!!',2,4); --#-->从第2个位置截取,截取4个字符,结果为:ello
select substring('hello world!!,3'); --#-->从第3个字符开始,把后边所有都截取,结果为:llo world!!
--#查询数学成绩最高手学生的姓名
select name from grade where math=(select max(math) from grade); --#按照数学成绩的降序排序选取第一个就是最高分
select name from grade order by(math) desc limit 0,1; --#limit表示从第1行开始选择1行
sql学习之基础(MySql)的更多相关文章
- SQL学习笔记之MySQL索引知识点
0x00 概述 之前写过一篇Mysql B+树学习,简单的介绍了B+数以及MySql使用B+树的原因, 有了这些基础知识点,对MySql索引的类型以及索引使用的一些技巧,就比较容易理解了. 0x01 ...
- SQL学习笔记之MySQL查询的三层解析
Mysqld的三层结构: SQL类型: DDL:数据库对象定义语言 对库和表的定义 DML:操作语言 DCL:控制语言 结构化的查询语言:select * from user; 执行该语句时: 1.连 ...
- Oracle PL/SQL学习之基础篇(1)
1.PL/SQL,全称Procedure Language/SQL,过程化sql语言 PL/SQL的程序结构 declare --声明部分(包括变量.光标.例外声明) begin --语句序列(DML ...
- SQL学习笔记之MySQL中真假“utf8” 问题
0x00 MySQL中UTF8报错 最近我遇到了一个 bug,我试着通过 Rails 在以“utf8”编码的 MariaDB 中保存一个 UTF-8 字符串,然后出现了一个离奇的错误: Incorre ...
- Oracle PL/SQL学习之基础篇(2)--例外
1.例外分类:系统例外.自定义例外 (1)系统例外,参见相关API文档 (2)自定义例外 定义自己的例外:就像自定义变量一样,类型为exception 抛出例外:使用raise抛出自定义例外 set ...
- SQL学习笔记之MySQL查询练习2
(网络搜集) 0x00 数据准备 CREATE TABLE students (sno ) NOT NULL, sname ) NOT NULL, ssex ) NOT NULL, sbirthday ...
- [SQL] SQL学习笔记之基础操作
1 SQL介绍 SQL 是用于访问和处理数据库的标准的计算机语言.关于SQL的具体介绍,我们通过回答如下三个问题来进行. SQL 是什么? SQL,指结构化查询语言,全称是 Structured Qu ...
- SQL学习笔记六之MySQL数据备份和pymysql模块
mysql六:数据备份.pymysql模块 阅读目录 一 IDE工具介绍 二 MySQL数据备份 三 pymysql模块 一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测 ...
- spark SQL学习(spark连接 mysql)
spark连接mysql(打jar包方式) package wujiadong_sparkSQL import java.util.Properties import org.apache.spark ...
随机推荐
- Qt双缓冲机制:实现一个简单的绘图工具(纯代码实现)
http://blog.csdn.net/rl529014/article/details/51658350
- HDU 5724 Chess(博弈论)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5724 [题目大意] 给出一个n行,每行有20格的棋盘,棋盘上有一些棋子,每次操作可以选择其中一个棋 ...
- C模块回调Lua函数的两种方法
作者:ani_di 版权所有,转载务必保留此链接 http://blog.csdn.net/ani_di C模块回调Lua函数的两种方法 lua和C通过虚拟栈这种交互方式简单而又可靠,缺点就是C做栈平 ...
- Debug目录下没有.exe文件
记一下小笔记: VC6.0设置.exe文件的输出路径: Project->Settings->Link Category选择"General" 在Output file ...
- iOS中Block介绍 基础
ios开发block的使用指南,以及深入理解block的内存管理,也适用于osx开发.讨论范围:block的使用,内存管理,内部实现.不包含的内容:gc arc下的block内存,block在c++中 ...
- SQL Server索引进阶:第五级,包含列
原文地址: Stairway to SQL Server Indexes: Level 5, Included Columns 本文是SQL Server索引进阶系列(Stairway to SQL ...
- 仿36氪(iOS版附源代码)
前言: 这是我2016年3月开始写的,利用课余时间全心投入的项目,本以为是凭着轻松愉悦的方式来学习的,中途遇到bug解决bug的时候,每天晚上几乎都是写到寝室关灯,还有一次使用Github不当写了五天 ...
- 【JS控制图片显示的大小(图片等比例缩放)】
效果: 代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ...
- [NOIP2001提高组]CODEVS1014 Car的旅行路线(最短路)
最短路,这个不难想,但是要为它加边就有点麻烦..还好写完就过了(虽然WA了一次,因为我调试用的输出没删了..),不然实在是觉得挺难调的.. ------------------------------ ...
- dubbo架构演变之路
背景 (#) 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时, ...