创建数据库

1
create database dbname;

删除数据库

1
drop database dbname;

选择数据库

1
use dbname;

创建表

1
2
3
4
5
6
7
8
CREATE TABLE IF NOT EXISTS `book`(
`id` INT UNSIGNED AUTO_INCREMENT,
`title` VARCHAR(100) NULL,
`author` VARCHAR(40) NOT NULL,
`date` DATE,
INDEX title_index(title(100)),
PRIMARY KEY ( `id` )
)ENGINE=InnoDB;
  • AUTO_INCREMENT定义列为自增的属性,默认自增1,一般用作主键
  • NOT NULL指定该字段不能为空, 在操作数据库时如果输入该字段的数据为NULL ,就会报错
  • PRIMARY KEY关键字用于定义列为主键
  • ENGINE 设置存储引擎
  • CHARSET 设置编码
  • INDEX设置列为普通索引、也可以使用UNIQUE指定唯一索引、 FULLTEXT指定全文索引

添加表字段

1
alter table book add press varchar;

删除表字段

1
alter table book drop press;

修改表字段

1
alter table book modify press char;

查看表结构

1
show columns from book;

修改表名

1
alter table book RENAME TO book1;

删除表

1
drop table book;

创建索引

1
2
3
create index title_index ON book(title(100)); 

alter table book ADD INDEX title_index(title);

删除索引

1
drop index title_index ON book;

插入数据

1
2
3
4
5
6
7
insert into book values(值1,值2,....);#值的顺序与字段在表中的顺序一致

insert into book(title,author)
values('Java学习路线','Java学习录');#为指定字段赋值 insert into book(title,author)
select title,author from test;#copy另一张表的数据

修改表数据

1
update table set title='学习笔记',date='2019-05-21'

删除表数据

1
2
3
truncate table book;#删除表中所有数据

delete from book where xx=yy;#根据条件删除表中数据

查询

1
select * from book;

常用函数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
character_length("title") #字符串title的字符数
concat("title","author") #将字符串title和author合并为一个字符串
concat_ws(",""title","author") #将字符串title和author合并为一个字符串,合并时使用逗号作为分隔符
lower("title") #将字符串title的内容转为小写
upper("title") #将字符串title的内容转为大写
reverse("title") #反转字符串title
abs("price") #求price的绝对值
avg("price") #求price的平均值
count("price") #求price的总记录数
max("price") #求price的最大值
min("price") #求price的最小值
sum("price") #求price的和
rand()#返回0-1之间的随机数
adddate("date",n) #date加上n天的时间
addtime("date",n) #date加上n秒的时间
curdate() #当前日期
current_time() #当前时间
current_timestamp() #当前日期时间
datediff(d1,d2) #d1和d2相隔的天数
period_diff(d1,d2) #d1和d2相隔的月数
subdate(d,n) #d减去n天的日期
subtime(d,n) #d减去n秒的时间
connection_id()#服务器当前连接数

case when

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
CASE expression
WHEN condition1 THEN result1
WHEN condition2 THEN result2
..
WHEN conditionN THEN resultN
ELSE result
END
#CASE 表示函数开始
#END 表示函数结束
#如果 condition1 成立
#则返回 result1
#如果 condition2 成立
#则返回 result2
#当全部不成立则返回 result
#而当有一个成立之后,后面的就不执行了

IF

1
IF(expr,v1,v2)#如果表达式 expr 成立,返回结果 v1;否则,返回结果 v2。

IFNULL

1
IFNULL(v1,v2)#如果 v1 的值不为 NULL,则返回 v1,否则返回 v2

去除结果集中的重复元素

1
select distinct(title) from book;

模糊查询

1
2
3
select * from book where title="Java%";#查询以Java开头的数据,只有这样使用索引以下两种不使用索引
select * from book where title="%Java";#查询以Java结尾的数据
select * from book where title="%Java%";#查询包含Java的数据

合并结果集

1
select title from book1 union select title from book2

连接(left jion/right jion/jion/逗号)

1
2
3
4
select * from book1 left jion book2 where xx=yy #获取左表所有记录,即使右表没有对应匹配的记录
select * from book1 right jion book2 where xx=yy #获取右表所有记录,即使左表没有对应匹配的记录
select * from book1 jion book2 where xx=yy #获取两个表中字段匹配关系的记录
select * from book1 , book2 where xx=yy#同jion

分组

1
select count(*) from book group by author ='Java学习录' #查询公众号Java学习录一共写了多少篇文章

排序

1
2
select * from book order by date ASC#默认就是ASC 可省略,按date升序排列
select * from book order by date DESC#按date降序排列

分页

1
2
3
select * from table limit 5; #返回前5行
select * from table limit 0,5; #同上,返回前5行
select * from table limit 5,10; #返回6-15行

MySQL常用sql语句大全的更多相关文章

  1. 常用SQL语句大全

    一些常用SQL语句大全   一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql se ...

  2. Mysql 常用 SQL 语句集锦

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  3. Mysql 常用 SQL 语句集锦 转载(https://gold.xitu.io/post/584e7b298d6d81005456eb53)

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  4. mysql 常用 sql 语句 - 快速查询

    Mysql 常用 sql 语句 - 快速查询 1.mysql 基础 1.1 mysql 交互         1.1.1 mysql 连接             mysql.exe -hPup    ...

  5. php面试专题---MySQL常用SQL语句优化

    php面试专题---MySQL常用SQL语句优化 一.总结 一句话总结: 原理,万变不离其宗:其实SQL语句优化的过程中,无非就是对mysql的执行计划理解,以及B+树索引的理解,其实只要我们理解执行 ...

  6. Mysql常用sql语句(一)- 操作数据库

    21篇测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html ...

  7. Mysql常用sql语句(二)- 操作数据表

    21篇测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html ...

  8. Mysql常用sql语句(八)- where 条件查询

    测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html 前言 ...

  9. Mysql常用sql语句(九)- like 模糊查询

    测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html 前言 ...

随机推荐

  1. Spring Boot版本号说明

    Spring Boot的版本选择一般是这样的,如下图: 那版本号后面的英文代表什么含义呢? 具体含义,如下文所示: SNAPSHOT:快照版,表示开发版本,随时可能修改: M1(Mn):M是miles ...

  2. 微信(十一) 使用调试助手申请设备ID和报备流程

    以下流程模拟了一个设备,从微信硬件申请一个产品IP,对此ID进行报备生效,查询自己的绑定主人,给绑定主人发送消息的一系列http请求流程. 1 获取微信密钥 下面需要在公众号设备电脑IP白名单的电脑才 ...

  3. cc2530的第三次实验,按键中断控制流水灯

    cc2530的第三次实验:按键中断控制流水灯 效果为按一次按键,流水灯亮一次 实验相关电路图: 实验相关寄存器: 初始化函数 //初始化LED灯 //设置P1SEL,通用为0,外设为1 1111110 ...

  4. Pandas | 22 时间差

    时间差(Timedelta)是时间上的差异,以不同的单位来表示.例如:日,小时,分钟,秒.它们可以是正值,也可以是负值.可以使用各种参数创建Timedelta对象,如下所示 - 字符串 通过传递字符串 ...

  5. 以py脚本形式ORM操作 及 django终端打印sql语句的设置

    1. 在Django项目的settings.py文件中,在最后复制粘贴如下代码: LOGGING = { 'version': 1, 'disable_existing_loggers': False ...

  6. 洛谷 P1234 小A的口头禅

    这里是传送门啊 I'm here! 题目描述 小A最近有了一个口头禅"呵呵",于是他给出了一个矩形,让你求出里面有几个hehe(方向无所谓). 输入输出格式 输入格式: 第一行两个 ...

  7. 【字符串】KMP

    Algorithm Task 给定一个文本串 \(S\) 和一个模式串 \(T\),求 \(T\) 在 \(S\) 中出现的所有位置. Limitations 要求时空复杂度均为线性. Solutio ...

  8. vue-waterfall2 实现瀑布流,及总结的问题

    1.安装 npm install vue-waterfall2@1.8.20 --save    (提示:一定要安装1.8.20,最新版会有一部分问题) 2.打开main.js文件 import wa ...

  9. 编译udf小软件(附视频教程)

    小软件下载地址(不仅支持Visual Studio并且打包gcc,解压即可编译): https://pan.baidu.com/s/1XPfjfY8DC2KKS8gj1KhutQ 提取码: 6kju ...

  10. eclipse&myeclipse 生成jar包后,spring无法扫描到bean定义

    问题:eclipse&myeclipse 生成jar包后,spring无法扫描到bean定义 在使用getbean或者扫包时注入bean失败,但在IDE里是可以正常运行的? 原因:导出jar未 ...