data:image/s3,"s3://crabby-images/b08a1/b08a122f2b1d37fc5d59076e726dde6aa0cde00f" alt=""
来自之前cnblog的博客
源地址:https://www.cnblogs.com/This-is-Y/p/11252206.html
安装:
安装phpstudy,通过phpstdy来学习MySQL。
data:image/s3,"s3://crabby-images/a8587/a858769d7872ceef4424b9336a428593406035d4" alt=""
然后登陆mysql,使用你的密码登陆(默认是root)
之后就可以开始学习mysql语句了。
使用:
mysql语句不区分大小写,每一个命令都是以;结束(如create database sqlname;)
\h获取帮助
\c退出编辑(如图)
data:image/s3,"s3://crabby-images/86895/86895d38973e52e1645eca5dfe51418ea5dd38fa" alt=""
进入’>模式时,使用\c退出到->(如图)
data:image/s3,"s3://crabby-images/dc247/dc247622d769903103d1d0dfa5e0b47c66b72480" alt=""
增加:CREATE DATABASE ’数据表名字‘;(如create database sqlname;)
创建内容:
create table teacher(
id int(4) not null primary key auto_increment,
name char(20) not null,
sex char(10) not null,
addr char(10) not null
);
插入数据:insert into teacher(name,sex,addr) values(‘Y’,’male’,’jxpx’);
检索数据:
1,* 通配符:
select * from teacher;(*表示所有,这个select关键字本来是查找某个数据)
之后就是这个样子:
2,distinct (独特的)关键字,不显示重复的。如:
select distinct name from teacher;
然后就是:
3,限制数据
在各个数据库中的实现各不一样
SQL Server和Access中:select top 4 id from teacher;
DB2:select id from teacher fetch first 5 rows only;
Oracle:select id from teacher where rownum <= 5;
MySQL,MariaDB,PostgreSQL,SQLite:select id from teacher limit 5;
切换到一个数据库:use ’数据表名字‘;(如use test)
显示所有数据库:show databases;
如图:
在数据库中显示数据表:show tables;
data:image/s3,"s3://crabby-images/86c6d/86c6d7967baa9a62e01bc4414545c86c5e00c4c8" alt=""
更新数据: update teacher set name=’Josely’ where id=5;
更新前: 更新后:
删除数据: delete from teacher where id=5;
删除前:参考前面的图,删除后:
data:image/s3,"s3://crabby-images/d76f7/d76f792205de29f8ad277a74ed3799db80b3b375" alt=""
where句子:
select 你要的信息 from 一个表或者多个表 where 满足的条件(判断)
如:select * from teacher where sex=‘male’;
如:select name from teacher where sex=‘male’;
where 语句可以加上and 与or 进行连接,以及()
order by 语句:
select 你要的信息 from 一个表或者多个表 order by 字段 asc/desc
asc与desc表示正序与逆序(默认为asc,可以不写)
如 select * from teacher order by name;
data:image/s3,"s3://crabby-images/fe9b6/fe9b6a3b4442e1129007c97915a7d0ee2fb6b714" alt=""
select * from teacher order by name desc
data:image/s3,"s3://crabby-images/14760/14760dc71992f61cb30b17335cf41c0b530ad127" alt=""
此时,注意,order by 后面可以加数字(在sqli中有用的)
select * from teacher order by 1;(1=id)
select * from teacher order by 2;(2=name)
select * from teacher order by 3;(3=sex)
select * from teacher order by 4;(4=addr)
like 操作符:
** **创建比较特殊数据的搜索模式
样例表:
1:% 表示任意字符出现任意次数
如:select * from student where name like ‘l%’;
2:_ 用法与%一样,但是只匹配单个字符
如:select * from student where name like ‘j‘
3:[] 指定一个字符集,他必须匹配指定位置(通配符的位置)的一个字符
如:……我的MYSQL用不了[]…………淦
字段:
** **字段连接:‘+’只能连接数字,连接字符串要用concat()
union语句:
select 需要的信息 from 数据表1 union select 需要的信息 from 数据表2
如图两个表:
data:image/s3,"s3://crabby-images/2d9fa/2d9fa4e3d711d8e3e6176a4e78477246b31a9df5" alt=""
使用select name from student union select name from teacher;后,
data:image/s3,"s3://crabby-images/b06d6/b06d61c24cd8900612c3aa1e21689ce9329804fd" alt=""
值得注意的是,这样子写,不会显示重复的(name为Y的两个数据只显示一个)
要显示两个,应使用union all。
select name from student union all select name from teacher;
效果如下图
使用union,还可以这样子玩:
data:image/s3,"s3://crabby-images/0b3a7/0b3a72fa26efd37caa57ffa857b15d9c2c7d4361" alt=""
注释:
使用#字符,或– (减号减号空格)来注释单行,还有一个/* */。
data:image/s3,"s3://crabby-images/f1e04/f1e0415805134a24c6d31d2fea16ffbf4a3da0c6" alt=""
data:image/s3,"s3://crabby-images/78642/78642b9c9885b7e67c716515a960dd2ef1cdb458" alt=""
内置函数:
database():
data:image/s3,"s3://crabby-images/ae1ee/ae1ee874fabf28e444a0289cebccc59a40ed0635" alt=""
load_file(‘写文件路径’):
data:image/s3,"s3://crabby-images/bd3e4/bd3e4ed198458de9e4870673084766c2c77d8084" alt=""
(不知道为啥没有。。。。)
current_user:
data:image/s3,"s3://crabby-images/fbe06/fbe06e385cc1b76873b572e21590c67bfae31bcd" alt=""
当出现时:
原因是没有选择一个数据库,可以先show databases;查看有哪些数据库,再use ’数据库名‘ 来使用一个数据库。