mysq数据库管理工具navicat基本使用方法
navicat是mysql数据库的客户端查询管理工具,本文详细的介绍了该软件的基本使用方法
本文转自 http://hejiawangjava.iteye.com/blog/2245758
sql是操作数据库中数据的语句,在不同的数据库中会略有不同,如mysql,postgreSQL,oracle,sqlserver,sqlite等等,但是sql的基础select、insert、update、delete语句都是相同的,本文只是介绍如何在mysql中,利用navicat可视化工具学习sql语句的select、insert、update、delete基础,这四种语句是sql基础中的基础了,但是万变不离其中,其他复杂的语句也都是这四种语句的组合。
本文没有介绍数据库的函数、优化数据库、优化sql语句等深层次只是,有sql基础的自行绕过。。。。
select——查询
insert——插入
update——更新
delete——删除
from——从哪个表
where——查询条件
join——表连接
order by——排序
一、确保mysql安装成功,下图是mysql安装成功,并启动服务的标志:
1、计算机右键——管理——服务和应用程序——服务,查看mysql服务是否开启
data:image/s3,"s3://crabby-images/7d618/7d6180b7fcce7462a20f43e4afdfea0c08ad58e4" alt=""
二、打开navicat软件,将navicat与本地mysql服务连接:
data:image/s3,"s3://crabby-images/411cc/411cc1c95a3d8efc9ec2690215b298647d3c4845" alt=""
点击connection——选择mysql,出现下图界面:
data:image/s3,"s3://crabby-images/d47b0/d47b07adafcf3579329631783a5db21638af45b5" alt=""
按照自己安装mysql中的信息,填好。出现下面的信息,证明连接成功:
data:image/s3,"s3://crabby-images/b5faa/b5faae1c64162486f99cdf35a01c034dbf415940" alt=""
三、创建数据库
首先打开一个执行sql语句的窗口:
data:image/s3,"s3://crabby-images/73539/735391cd9624f23d3d8c86b63302da19fccd9bb8" alt=""
执行创建数据库的sql语句
data:image/s3,"s3://crabby-images/cef16/cef16d77008e957207c3ff79ad7da383358cd5f0" alt=""
创建数据库的sql执行后,要刷新,在下图位置,右键,点击refresh
data:image/s3,"s3://crabby-images/c2c71/c2c71c4cd6162b65d47baadd2173dde1fdc22ee2" alt=""
然后就能看见新建的sqltest数据库了
四、创建表的语句
data:image/s3,"s3://crabby-images/ab6ce/ab6cee35e2fbb1c5170ddadc8a35c745f4b4e49f" alt=""
首先打开sqltest数据库执行sql的窗口,注意,刚才打开执行sql的窗口是执行整个数据库的sql的窗口,现在我们要在sqltest数据库中执行sql语句,那么就要打开sqltest的sql窗口。
在上图红箭处Querries右键新建一个query,就打开了执行sql的窗口,
然后执行创建表的sql语句:
(主键外键的知识没有说明,,,)
data:image/s3,"s3://crabby-images/aae9f/aae9f51b33a51d385c56340426b802ea0bcd2b35" alt=""
利用软件添加一条数据:
data:image/s3,"s3://crabby-images/42077/42077d921fbc2e53fdeac8688ba2c3a0e21d6f56" alt=""
五:insert语句:
打开执行sql语句的窗口,写入sql语句:
data:image/s3,"s3://crabby-images/6907a/6907a81ba38cbd4388f7917b49557381be50a5ab" alt=""
这条sql语句的意思是,向test表中,添加一条数据,id为2,name为test2,age为21,
刷新test表,就能查看到test表中多了一条刚刚insert进去的数据。
六、select语句
利用select语句查看表中的数据:
data:image/s3,"s3://crabby-images/4c080/4c08041d0a600e718ae3dbe51e04715fb60f3679" alt=""
select * 意思是查询所有属性,
下面是带查询条件的sql语句:
data:image/s3,"s3://crabby-images/8daf1/8daf132e8a4f8e58ac05bf879bf5269dc12d0694" alt=""
这条sql语句的意思是,查询在test表中,id为1的数据,将这条数据的name属性和age属性查询出来。
七、update语句
data:image/s3,"s3://crabby-images/5ed3e/5ed3ef2c8993ab88a3b61c8eb05ebf9d160c2b49" alt=""
八、delete语句
data:image/s3,"s3://crabby-images/a812d/a812d042e980ccfaa59c79a29c5e929e6ea186c1" alt=""
九、表连接查询,
现在我们建立两张表(我口述,读者按上文的方式,自己建表吧。。。),学生表student,和 教师teacher
表,表结构和其中的数据如图:
student表:id是主键(一条数据的标识,每条数据的主键肯定不同)
name:学生姓名
teacher_id:该学生所对应的教师的id(是个外键)
data:image/s3,"s3://crabby-images/4c1b7/4c1b716a9276d7670641ab9ac184ba2d9e08be14" alt=""
teacher表:
id:主键
name:姓名
data:image/s3,"s3://crabby-images/00128/00128ef12b32ed57ac3bc662a96f7608a3a7d2e0" alt=""
现在我想知道”学生zhangsan的老师的名字是什么“。
在student表中,能够看出,学生zhangsan所对应的教师的id,也就是teacher_id是1,在teacher表中,id为1的教师的那么是teacher1,那么就能得出学生zhangsan的老师的名字是teacher1,
那么用sql怎么实现呢,这就是表的连接:
data:image/s3,"s3://crabby-images/570dd/570ddc2a5ce4eb767d9629227500e82b438e76bf" alt=""
上面图中的sql语句就是一个最简单的表连接,能够看出就是最基本的select、from、where组合,
上图中的sql首先去看括号中的语句,也就是 select teacher_id from student where name='zhangsan'
这条语句能够查询出名字为zhangsan的学生的teacher_id ,我们能在表中找出值为1,那么剩余的也就是括号外的sql语句就变成了 select name from teacher where id=1; 这样,教师的名字就得到了
十、其他重要的sql语句,
select count(*) from test 查询test表中共有多少条数据
select count(*) from test where age=21 查询test表中age为21的数据一共有多少条,
select count(*) from test where age>21 查询test表中age大于21的数据一共有多少条,数据库中的int类型支持大于小于等比较。
select count(*) from test where age>21 and age<30 查询test表中age大于21并且小于30的数据一共有多少条
select * from test order by id desc 按id降序排序
——还有一种查询是查询从第几条到第几条,也就是分页查询, 不同的数据库sql语句不同,mysql数据库用的是limit语句,oracle用rownum语句。。。
还有很多查询方式,但都是select、from、where。。。。这些基础的组合。。。。。。
在数据库中自己会有一些运算的函数,比如求和的add函数等,还能自定义函数,函数就比较难了,,不再这基础篇写了。
sql语句知识很多,这里只是总结了最基础的一点点东西,其他的知识也有从这些基础知识中演化出来的,多加练习,会的东西会越来越多,
不同的数据库的sql是会有不同,但是一个数据库的sql会了,其他数据库的sql也就会了,所以在刚学sql时,没必要特意挑选数据库。
My Git : https://github.com/hejiawang
网友评论