第一次真正意义上使用数据库,当然是从简单方便的mysql开始了,咱们不好高骛远扯些有的没的。
对于mysql来说虽然可以用phpmyadmin这样的东西,但是这还是会略显臃肿,既然是程序员,还是尽量使用简单清楚的命令行来写吧~~
第一次系统的搞这个难免摸不着头脑,下面就一步一步开始学习吧。
登陆和退出
登陆时用如下命令即可:
1 | mysql -h 主机地址 -u 用户名 -p |
其中很明显-h是指host,-u是指user,-p是指passwd。
这时候命令行会等待我们输入密码,这时候输入密码即可(没有回显)。
需要注意的是,如果想在一条语句里面输密码的话,-p后面是要马上接密码,中间不能有空格(显然这时候输的密码是会被回显出来的)。
登陆后,shell的提示符就会变成mysql的提示符了:
1 | mysql> |
在这里输入适当的语句并以”;”结尾即可。
退出时输入exit或者Ctrl+d都可以。
选择数据库和表
显示数据库
1 | mysql> show databases; |
创建数据库
1 | mysql> create database mydatabase; |
使用该数据库
1 | mysql> use mydatabase; |
显示数据库中所有的表
1 | mysql> show tables; |
删除表
1 | mysql> drop table mydatabase; |
显示表结构
1 | mysql> describe mytable; |
or
1 | mysql> desc mytable; |
显示格式如下:
1 | mysql> desc mytable; |
增删查改
增删查改的内容就是普通的sql语句了,这里不做解释,需要的时候再找也不迟。
批处理
导入数据
对于需要导入大量数据的时候,我们可以将需要的数据写成一个数据文件,数据文件中每一行就是一条记录;每条记录中的字段是按照表中的字段顺序排列,用TAB键进行分割。最后输入以下命令:
1 | mysql> load data local infile "b.txt" into table mytable; |
上面是将b.txt中的数据导入到mytable表中,这个文件名需要加引号。
需要注意的是数据文件中的字符串是不用加引号的,而且也可以直接写null。
执行SQL命令
对于现成的sql命令,我们可以在mysql提示符中直接这样加以执行。
1 | mysql> source a.sql |
这个文件名不用加引号。
或者也可以在bash中执行:
1 | $mysql -h localhost -u root -p <a.sql> ans.txt |
其中ans.txt是查询的结果,尖括号不可以省略,输出文件也不可以省略。通过这个方法我们就能把执行结果写入文件了。
存储过程
存储过程感觉就是一种函数,可以执行一些简单的逻辑,封装了零零散散的SQL语句。
修改标志
在创建过程之前我们需要修改下语句的结束标志,因为过程本身是一条SQL语句,但是过程又是由多条SQL语句组成的,这样我们就无法判断过程的结束标志了。因此我们需要修改下外层的结束标志,默认的结束标志是”;”,我们可以如下修改成其他的标志:
1 | mysql> delimiter $ |
这样SQL语句的结束标志就标称了”$”,这样我们就可以在过程内部仍然用”;”作为单个语句的结束标志了。不过最后我们还是要记得把他修改回常用的标志“;”;
创建过程
1 | mysql>create procedure mypro() |
这样我们就创建了一个简单的过程mypro。这个过程是数据库级的,因此他是归属于我们当前选择的数据库的。
执行过程
1 | mysql> call mypro() |
call下即可。
操作语言
过程中我们经常会用到选择或循环之类的控制语句,这些东西的语法类似pascal,具体用到的时候查下即可,这里不做解释。
查看和删除过程
当然,我们需要对过程进行管理:
查看当前数据库中的过程:
1 | mysql> select `name` from mysql.proc where db = 'your_db_name' and `type` = 'PROCEDURE'; |
把your_db_name换成自己的数据库名即可。
删除某个过程:
1 | mysql> drop procedure mypro; |
参考资料
MySQL语法大全_自己整理的学习笔记
MySQL用文本方式将数据装入一个数据库表
MySQL存储过程详解 mysql 存储过程