时间:2021-07-01 10:21:17 帮助过:2人阅读
-h : 该命令用于指定客户端所要登录的MySQL主机名, 登录当前机器该参数可以省略;
-u : 所要登录的用户名;
-p : 告诉服务器将会使用一个密码来登录, 如果所要登录的用户名密码为空, 可以忽略此选项。
创建新的数据库,则可以使用如下命令:
create database [IF NOT EXISTS] 数据库名
删除指定数据库,则可以使用如下命令:
drop database 数据库名
进入指定数据库,可以使用如下命令:
use 数据库名
查看当前实例下包含的数据库,可以使用如下命令:
show databases
查看当前数据库下所有的数据表,可以使用如下命令:
show tables
查看指定数据表的结构:
desc 表名
对于一些较长的语句在命令提示符下可能容易输错, 因此我们可以通过任何文本编辑器将语句输入好后保存为 .sql 的文件中,输入一下命令通过文件重定向执行该脚本:
mysql -u 用户名 -p 数据库名 < 存放位置
DDL语句是操作数据库对象的语句,包括创建(create)、删除(drop)和修改(alter)数据库对象。
创建数据表的语法如下:
create table 表名(列名 列类型 [约束条件]);
以创建学生信息表Student为例,表中存放学号(sno)、姓名(name)、性别(sex)、年龄(age)这些内容:create table student( sno int primary key, name char(8) not null, sex char(8) not null, age int);
在创建表后,想对表进行修改,可以使用alter语句来实现。
alter table 表名 add 列名 列数据类型 [after 插入位置]
alter table 表名 change 列名称 列新名称 新数据类型
alter table 表名 drop 列名称
alter table 表名 rename 新表名
删除整张表的语法如下:
drop table 表名
DML主要操作数据表里的数据,使用DML可以实现“插入新数据”、“修改已有数据”、“删除不需要的数据”。
insert语句可以用来将一行或多行数据插到数据库表中,语法如下:
insert into 表名([列名1,列名2,…])) values(值1,值2,…)
update语句用于修改数据表的记录,每次可以修改多条记录,通过使用where子句限定修改哪些记录,语法如下:
update 表名 set 列名称=新值 where 更新条件
delete语句用于删除表中的数据,语法如下:
delete from 表名称 where 删除条件
select语句是SQL语句中功能最丰富的语句,select语句可以执行单表查询、子查询以及多表连接查询等。
单表查询的select语句的语法格式如下:
select 列1,列2… from 表名称 where 查询条件
子查询就是指在查询语句中嵌套另一个查询,其语法格式如下:
select 列1… from 表名称 where 列名称 [<, in] 子查询
有两张表,student(记录学生的学号、姓名等信息)、grade(记录学生的学号、课程成绩),查询中grade表中学号所对应的学生姓名:
select name from student where sno in (select sno from grade)
很多时候,需要选择的数据并不是来自一个表,而是来自多个数据表,这就需要使用多表连接查询,其语法格式如下:
select 列1,列2… from 表1,表2… where 连接条件
有三张表,student(记录着学生的学号、姓名等信息)、course(记录着课程编号、课程名称)、grade(记录着学号、课程号、课程成绩),查询学生姓名、课程名称以及对于课程的成绩:
select s.name, c.name, g.grade from student s,course c,grade g where s.sno = g.sno and c.cno = g.cno
在MySQL中,可以使用Order by语句来实现按哪个字段哪种方式来进行排序,再返回搜索结果,具体语法如下:
select 列名1… from 表名 order by 列名 [asc,desc]
所谓的分组就是将一个数据表划分为若干个小区域,然后针对若干个小区域进行数据处理,具体语法如下:
select 分组字段,聚合函数 from 表名 group by 分组字段 [having 过滤条件]
有一张表grade,记录着考生号、课程编号、课程成绩,根据考生号进行分组,查询每位考生的课程总成绩:
select sno,sum(grade) from grade group by sno order by sum(grade) asc
事务是连续的一组数据库操作,即一段sql语句的批处理,这个批处理,不可分割,要么都执行,要么回滚都不执行。
为什么要使用事务这个技术呢?现在的很多软件都是多用户、多程序、多线程的,对同一个表可能有很多人在用,为保持数据的一致性,所以提出了事务的概念。这样很抽象,举个例子:A要给B转钱,A的账户-1000元,B的账户就要+1000元,这两个update语句并需作为一个整体来执行,不然A扣钱了,B没有加钱这种情况很难处理。
事务有以下四个标准属性, 缩写ACID,通常被称为:
原子性(Atomic): 确保工作单元内的所有操作都成功完成,否则事务将被中止在故障点,和以前的操作将回滚到以前的状态;
一致性(Consistent): 确保数据库正确地改变状态后,成功提交的事务;
隔离性(Isolated): 使事务操作彼此独立的和透明的;
持久性(Durable): 确保提交的事务的结果或效果的系统出现故障的情况下仍然存在。
MySQL中使用begin、rollback、commit、savepoint来实现事务处理:
begin:开始一个事务
rollback:事务回滚
commit:事务提交
savepoint:在事务中创建一个保存点
以表grade(记录学生学号、课程编号、课程成绩)为例,介绍一个示例来阐述事务的使用:
begin;
insert into grade values(103,01,88.8);
select * from grade;
savepoint first;
insert into grade values(103,02,90);
select * from grade;
rollback to first;
select * from grade;
commit;
我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
存储过程通常有以下优点:
MySQL存储过程创建的格式如下:
create procedure 过程名([过程参数][参数名][参数型别]…) 过程体
删除存储过程的格式如下:
drop procedure 过程名
调用存储过程的命令很简单,格式如下:
call 过程名(参数1,参数2…)
下面用一个简单的示例,介绍下存储过程的创建与使用:
创建存储过程
//使用&&来代替;作为分隔符
delimiter &&
create procedure test(IN input int)
begin
select input;
set input = 2;
select input;
end;&&
使用存储过程
//将分隔符声明为默认的;
delimiter ;
call test(3);
尽管我们可以在命令提示符下通过一行行的输入或者通过重定向文件来执行mysql语句, 但该方式效率较低, 由于没有执行前的语法自动检查, 输入失误造成的一些错误的可能性会大大增加, 这时不妨试试一些可视化的MySQL数据库管理工具, MySQL Workbench 就是 MySQL 官方 为 MySQL 提供的一款可视化管理工具, 你可以在里面通过可视化的方式直接管理数据库中的内容, 并且 MySQL Workbench 的 SQL 脚本编辑器支持语法高亮以及输入时的语法检查, 当然, 它的功能强大, 绝不仅限于这两点。
MySQL Workbench官方介绍: http://www.mysql.com/products/workbench/
MySQL Workbench 下载页: http://dev.mysql.com/downloads/tools/workbench/
MySQL使用总结
标签: