网站推荐、资源下载等 | 个人网站

MYSQL的基本语句

连接

1、mysql -h localhost -u root -p ******(回车)
2、mysql -h localhost -u root -p(回车)
******(回车)
3、mysql -u root -p ******(回车)(这个不写-h的话也是默认链接localhost)
4、mysql -u root -p(回车)
******(回车)
(这里的root是用户名,******是密码。这是在本机测试)

退出

MYSQL>exit(回车)

或者

MYSQL>quit(回车)

查看库

MYSQL>show databases;(回车)
(这里注意结束语句是英文状态下的分号)

创建库

MYSQL>create database mysql2;(回车)
(这里的mysql2是要创建的库名)

选中库

MYSQL>use mysql2;(回车)
(这里的mysql2是要选中库的名)

查看表

MYSQL>show tables;(回车)
(下表是空的,因为是刚刚创建的库)

删除库

MYSQL>drop database test;(回车)
(这里的test是要删除的库名)

创建表

MYSQL>create table class (
stu int,
name varchar(20),
age int
 );(回车)

改表名

MYSQL>rename table class to newClass;(回车)
(这里的class是要改的表名,newClass是新的表名)

删除表

MYSQL>drop table newClass;(回车)
(这里的newClass是要删除的表名)

描述表的结构

MYSQL>desc class;(回车)

 

增加

MYSQL>insert into class
(stu,name,age)
values
(1,'zhangsan',23);(回车)

设置编码格式

MYSQL>set names GBK;(回车)

查找

MYSQL>select * from class;(回车)
(这表示查找class表下的所有信息)

或者

MYSQL>select stu,name from class;(回车)
(表示只看class表下的stu和name列的所有信息)
MYSQL>select * from class stu = 2;(回车)
(表示只看class表下的stu=2行的所有信息)
MYSQL>select stu,name from class stu = 2;(回车)
(表示只看class表下的stu和name列的stu=2行的所有信息)

修改

MYSQL>update class
set
stu = 3,
age = 244
where
stu = 2;(回车)
(这里的class是要修改的那个表下面的,set到where中间是要修改的内容,where后面的是定位)

删除

MYSQL>delete from class
where
stu = 3;(回车)
(这里的class是在那个表下面删除,where后面的语句是定位功能)

数据类型

1、正数类型
tinyint、smallint、mediumint、int、bigint

1、tinyint:1个字节,能表示的范围是-2^7~2^7-1(-128~127),如果声明是无符号unsigned的,则能表示的范围是0~2^8(0~256);

2、smallint:2个字节,能表示的范围是-2^15~2^15-1(32,768~32,767),如果声明是无符号unsigned的,则能表示的范围是0~2^16(0~65,535);

3、mediumint:3个字节,能表示的范围是-2^23~2^23-1(-8,388,608~8,388,607),如果声明是无符号unsigned的,则能表示的范围是0~2^24(-16,777,216~16,777,215);

4、int:4个字节,能表示的范围是-2^31~2^31-1(-21,4748,3648~21,4748,3647),如果声明是无符号unsigned的,则能表示的范围是0~2^32(0~4,294,967,296);

5、bigint:8个字节,能表示的范围是-2^63~2^63-1(-922,3372,0368,5477,5808~922,3372,0368,5477,5807),如果声明是无符号unsigned的,则能表示的范围是0~2^64;
2、小数类型
float、double、decimal

在mysql下不管几个字节,使用时

1、float(M,D):M表示除了小数点外的所有位数,D表示小数点的位数。

例如:float(4,2)表示的范围是-99.99~99.99

2、decimal(M,D):M表示除了小数点外的所有位数,D表示小数点的位数。

例如:decimal(4,2)表示的范围是-99.99~99.99

这两者的区别是,decimal更精确。

字符类型

char、varchar、text

也是不用管几个字节,使用时

1、char(M):M表示能放几个字符,是定长,在内存中就是占M和字符。但是char类型不能存放字符串末尾有空格的。在utf-8码表下,一个中文的字符所占的是三个字节。

2、varchar(M):M表示能放几个字符,是不定长,实际中占N<=M个字符,那么在内存中所占的是N个字符。

3、text:是存放文本的,但是不常用,可以选择char和varchar。

时间日期类型

year、date、time、datetime

也是不用管几个字节,使用时

1、year:的存放范围1901~2155和0000,这里的0000是存放非法输入和没有输入时。输入两位数也行,如果输入的是01~69就代表输入的是2001~2069,如果输入的是70~99就代表输入的是1970~1999。

2、date:的存放范围1000-01-01~9999-12-31

3、time:的存放范围-838:59:59~838:59:59

4、datetime:的存放范围1000-01-01 00:00:00~9999-12-31 23:59:59

查询的五种语法where、group by、having、order by、limit

1、where的功能主要是用来定位的
2、group by是分组

一般配合max、min、sum、avg、count这五个统计函数来使用

max:求最大

min:求最小

sum:求总和

avg:求平均

count:求总行数

3、having是对查询结果的临时表进行筛选操作
4、order by是排序
5、limit起到限制条目作用

使用案例


三种子查询where、from、exists

1、where型子查询:把内层查询的结果当作外层的比较条件

2、from型子查询:把内层的查询结果当成临时表,供外层sql再次查询

3、exists型子查询:把外层的查询结果,拿到内层的查询是否成立

使用案例


union的使用

联合的意思,即把两次或多次查询结果合并起来。

UNION 用于合并两个或多个 SELECT 语句的结果集,并消去表中任何重复行。
UNION 内部的 SELECT 语句必须拥有相同数量的列,列也必须拥有相似的数据类型。
同时,每条 SELECT 语句中的列的顺序必须相同.

SELECT column_name FROM table1
UNION
SELECT column_name FROM table2

union all的话就是把重复的也保留下来

使用案例


左连接left join、右连接right join、内连接inner join的使用

使用案例

图示演示


 

列的增

MYSQL>alter table class add phone char(11);(回车)
(这里的class的表名,phone是增加的列名,char(11)是增加列名的数据类型)

列的删除

MYSQL>alter table class drop phone;(回车)
(这里的class的表名,phone是要删除的列名)

列的修改

MYSQL>alter table class change newAge age int;(回车)
(这里的class的表名,newAge是要修改的列名,age是修改后的列名,int是修改列名的数据类型,要和修改前的一样)

使用案例


 

视图view的使用

视图是虚拟的数据,默认情况下是保存语句

创建的视图

MYSQL>create view st as select * from class where id>2;(回车)
select * from st where id<6;(回车)

就等价于

MYSQL>select * from class where id>2 and id<6;

删除视图

MYSQL>drop view st;(回车)
(这里st是视图名)

修改视图

MYSQL>aletr view st as select * from class id < 6;(回车)
(这里st是视图名,class是表名)

使用案例


修改结束符

MYSQL>delimiter $(回车)
(此时结束符就为$)

创建触发器

增加类

MYSQL>create trigger triggerName1
after insert on buy
for each row
begin
update sell set sum = sum - new.sum where animal = new.animal;
end$(回车)
(这里的triggerName1是创建触发器的名,buy是要插入的数据表名,begin和嗯对之间的是sql语句,new点表示新插入的行。)

查看触发器

MYSQL>show triggers$(回车)
(这里的$是之前修改的结束符)

数据的备份与恢复

导出表

mysqldump -uroot -p123456 mysql2 sell buy>D:/sellANDbuy.sql
mysqldump -u用户名-p密码 库名 表1 表2>地址/备份文件名称

导出库下所有表

mysqldump -uroot -p123456 mysql2>D:/mysql2ALLtable.sql
mysqldump -u用户名-p密码 库名>地址/备份文件名称

导出库

mysqldump -uroot -p123456 -B mysql mysql2>D:/mysqlANDmysql2.sql
mysqldump -u用户名-p密码 -B 库名1 库名2>地址/备份文件名称

导出所有库

mysqldump -uroot -p123456 -A>D:/databases.sql
mysqldump -u用户名-p密码 -A>地址/备份文件名称

恢复库

1、不登录
mysql -uroot -p123456 <D:/mysql2.sql

mysql -u用户名-p密码 <地址/恢复文件名称
2、登录
source D:/mysql2.sql;

source 地址/恢复文件名称;

恢复表

1、不登录
mysql -uroot -p123456 mysql2<D:/sellANDbuy.sql

mysql -u用户名 -p密码 库名<地址/恢复文件名称
2、登录
use mysql2;
source D:/sellANDbuy.sql;
use 库名;
source 地址/恢复文件名称;

使用案例


存储引擎myisam、innodb

myisam

create table name (id tinyint) engine=myisam;

不支持事务,优势是访问速度快。

innodb

create table name2 (id tinyint) engine=innodb;

支持事务,但是访问速度相对慢。


事务的开启与提交

成功的

start transaction;(开始事务)
commit;(结束事务)

失败的

start transaction;(开始事务)
rollback;(事务结束回滚)

使用案例


 

普通索引、主键索引、唯一索引、全文索引

普通索引:index

仅仅是加快查询速度

主键索引:primary key

不能重复,主键至多只有一个

唯一索引:unique index

行上的值不能重复

全文索引:fulltext index

建立索引

alter table buy add index index1(sum);
alter table 表名 add 索引类型 [索引名](列名);(这里的索引名是可选)

查看一张表上所有索引

show index from buy;
show index from 表名;

删除索引

alter table buy drop index index1;
alter table 表名 drop index 索引名;

使用案例


存储过程

意思就是创建函数

创建一个存储

create procedure function1() begin
select * from buy;
end$(这里的function1是存储名,没有参数,select * from buy;是sql语句,$是修改的结束符)

使用存储

call function1()$
call 存储名()$

查看存储

show procedure status$

删除存储

drop procedure function1$
drop procedure 存储名$

创建有参的存储

create procedure function2(sum tinyint) begin
if sum=4 then
select * from class where id>sum;
else
select * from class where id<=sum;
end if;
end$

使用案例


 

posted @ 2018-07-03 20:26  xiaostudy  阅读(358)  评论(0编辑  收藏  举报
网站推荐
[理工最爱]小时百科 |  GitHub |  Gitee |  开源中国社区 |  牛客网 |  不学网论坛 |  r2coding |  冷熊简历 |  爱盘 |  零散坑 |  bootstrap中文网 |  vue.js官网教程 |  源码分享站 |  maven仓库 |  楼教主网站 |  廖雪峰网站 |  w3cschool |  在线API |  代码在线运行 |  [不学网]代码在线运行 |  JS在线运行 |  PHP中文网 |  深度开源eclipse插件 |  文字在线加密解密 |  菜鸟教程 |  慕课网 |  千图网 |  手册网 |  素材兔 |  盘多多 |  悦书PDF |  sumatra PDF |  calibre PDF |  Snipaste截图 |  shareX截图 |  vlc-media-player播放器 |  MCMusic player |  IDM下载器 |  格式工厂 |  插件网 |  谷歌浏览器插件 |  Crx搜搜 |  懒人在线计算器 |  leetcode算法题库 |  layer官网 |  layui官网 |  formSelects官网 |  Fly社区 |  程序员客栈 |  融云 |  华为云 |  阿里云 |  ztree官网API |  teamviewer官网 |  sonarlint官网 |  editormd |  pcmark10官网 |  crx4chrome官网 |  apipost官网 |  花生壳官网 |  serv-u官网 |  杀毒eset官网 |  分流抢票bypass官网 |  懒猴子CG代码生成器官网 |  IT猿网 |  natapp[内网穿透] |  ngrok[内网穿透] |  深蓝穿透[内网穿透] |  WakeMeOnLan[查看ip] |  iis7 |  [漏洞扫描]Dependency_Check官网 |  [图标UI]fontawesome官网 |  idea插件官网 |  路过图床官网 |  sha256在线解密 |  在线正则表达式测试 |  在线文件扫毒 |  KuangStudy | 
资源下载
电脑相关: Windows原装下载msdn我告诉你 |  U盘制作微PE工具官网下载 |  Linux_CentOS官网下载 |  Linux_Ubuntu官网下载 |  Linux_OpenSUSE官网下载 |  IE浏览器官网下载 |  firefox浏览器官网下载 |  百分浏览器官网下载 |  谷歌google浏览器历史版本下载 |  深度deepin系统官网下载 |  中兴新支点操作系统官网下载 |  文件对比工具Beyond Compare官网下载 |  开机启动程序startup-delayer官网下载 |  openoffice官网下载 |  utorrent官网下载 |  qbittorrent官网下载 |  cpu-z官网下载 |  蜘蛛校色仪displaycal官网下载 |  单文件制作greenone下载 |  win清理工具Advanced SystemCare官网下载 |  解压bandizip官网下载 |  内存检测工具memtest官网下载 |  磁盘坏道检测与修复DiskGenius官网下载 |  磁盘占用可视化SpaceSniffer官网下载 |  [磁盘可视化]WizTree官网下载 |  win快速定位文件Everything官网下载 |  文件定位listary官网下载 |  动图gifcam官网下载 |  7-Zip官网下载 |  磁盘分区工具diskgenius官网下载 |  CEB文件查看工具Apabi Reader官网下载 |  罗技鼠标options官网下载 |  [去除重复文件]doublekiller官网下载 | 
编程相关: ApacheServer官网下载 |  Apache官网下载 |  Git官网下载 |  Git高速下载 |  Jboss官网下载 |  Mysql官网下载 |  Mysql官网历史版本下载 |  NetBeans IDE官网下载 |  Spring官网下载 |  Nginx官网下载 |  Resin官网下载 |  Tomcat官网下载 |  jQuery历史版本下载 |  nosql官网下载 |  mongodb官网下载 |  mongodb_linux历史版本下载 |  mongodb客户端下载 |  VScode官网下载 |  cxf官网下载 |  maven官网下载 |  QT官网下载 |  SVN官网下载 |  SVN历史版本下载 |  nodeJS官网下载 |  oracle官网下载 |  jdk官网下载 |  STS官网下载 |  STS历史版本官网下载 |  vue官网下载 |  virtualbox官网下载 |  docker desktop官网下载 |  github desktop官网下载 |  EditPlus官网下载 |  zTree下载 |  layui官网下载 |  jqgrid官网下载 |  jqueryui官网下载 |  solr历史版本下载 |  solr分词器ik-analyzer-solr历史版本下载 |  zookeeper历史版本官网下载 |  nssm官网下载 |  elasticsearch官网下载 |  elasticsearch历史版本官网下载 |  redis官网下载 |  redis历史版本官网下载 |  redis的win版本下载 |  putty官网下载 |  查看svn密码TSvnPD官网下载 |  MongoDB连接工具Robo官网下载 |  dll查看exescope官网下载 |  dll2c官网下载 |  接口测试apipost官网下载 |  接口测试postman官网下载 |  原型设计工具AxureRP官网下载 |  canal官网下载 |  idea主题样式下载 |  vue的GitHub下载 |  finalShell官网下载 |  ETL工具kafka官网下载 |  cavaj[java反编译]官网下载 |  jd-gui[java反编译]官网下载 |  radmin[远程连接]官网下载 |  tcping[win ping端口]下载 |  jQueryUploadFile官网下载 |  RedisPlus下载 |  aiXcoder智能编程助手官网下载 |  [表单效验]validform官网下载 |  idea官网下载 |  RedisStudio下载 |  MD转word含公式pandoc官网下载 |  logviewer官网下载 |  Kafka官网下载 |  hbase高速下载 |  hadoop官网下载 |  hadooponwindows的GitHub下载 |  hive官网下载 |  soapui官网下载 |  flink官网下载 |  kafkatool官网下载 |  MinIO官网下载 |  MinIO中国镜像下载 | 
办公相关工具
免费在线拆分PDF【不超过30M】 |  免费在线PDF转Word【不超过10M】 |  在线文字识别转换【不超过1M】 |  PDF转换成Word【不超过50M】 |  在线OCR识别 |  Smallpdf |  文件转换器Convertio |  迅捷PDF转换器 |  字母大小写转换工具 |  档铺 |  快传airportal[可文字] |  快传-文叔叔 |  P2P-小鹿快传 |  [图床]ImgURL | 
网站入口
腾讯文档 |  有道云笔记网页版 |  为知笔记网页版 |  印象笔记网页版 |  蓝奏云 |  QQ邮箱 |  MindMaster在线思维导图 |  bilibili |  PDM文件在线打开 |  MPP文件在线打开 |  在线PS软件 |  在线WPS |  阿里云企业邮箱登陆入口 | 
其他
PDF转换 |  悦书PDF转换 |  手机号注册查询 |  Reg007 |  akmsg |  ip8_ip查询 |  ipip_ip查询 |  天体运行testtubegames |  测试帧率 |  在线网速测试 |