前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL常用操作

MySQL常用操作

作者头像
mythsman
发布2022-11-14 15:42:50
6020
发布2022-11-14 15:42:50
举报
文章被收录于专栏:mythsman的个人博客

第一次真正意义上使用数据库,当然是从简单方便的mysql开始了,咱们不好高骛远扯些有的没的。

对于mysql来说虽然可以用phpmyadmin这样的东西,但是这还是会略显臃肿,既然是程序员,还是尽量使用简单清楚的命令行来写吧~~

第一次系统的搞这个难免摸不着头脑,下面就一步一步开始学习吧。

登陆和退出

登陆时用如下命令即可:

代码语言:javascript
复制
mysql -h 主机地址 -u 用户名 -p

其中很明显-h是指host,-u是指user,-p是指passwd。

这时候命令行会等待我们输入密码,这时候输入密码即可(没有回显)。

需要注意的是,如果想在一条语句里面输密码的话,-p后面是要马上接密码,中间不能有空格(显然这时候输的密码是会被回显出来的)。

登陆后,shell的提示符就会变成mysql的提示符了:

代码语言:javascript
复制
mysql>

在这里输入适当的语句并以";"结尾即可。

退出时输入exit或者Ctrl+d都可以。

选择数据库和表

显示数据库

代码语言:javascript
复制
mysql> show databases;

创建数据库

代码语言:javascript
复制
mysql> create database mydatabase;

使用该数据库

代码语言:javascript
复制
mysql> use mydatabase;

显示数据库中所有的表

代码语言:javascript
复制
mysql> show tables;

删除表

代码语言:javascript
复制
mysql> drop table  mydatabase;

显示表结构

代码语言:javascript
复制
mysql> describe mytable;

or

代码语言:javascript
复制
mysql> desc mytable;

显示格式如下:

代码语言:javascript
复制
mysql> desc mytable;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(11)     | NO   | PRI | NULL    | auto_increment |
| value | varchar(50) | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

增删查改

增删查改的内容就是普通的sql语句了,这里不做解释,需要的时候再找也不迟。

批处理

导入数据

对于需要导入大量数据的时候,我们可以将需要的数据写成一个数据文件,数据文件中每一行就是一条记录;每条记录中的字段是按照表中的字段顺序排列,用TAB键进行分割。最后输入以下命令:

代码语言:javascript
复制
mysql> load data local infile "b.txt" into table mytable;

上面是将b.txt中的数据导入到mytable表中,这个文件名需要加引号。

需要注意的是数据文件中的字符串是不用加引号的,而且也可以直接写null。

执行SQL命令

对于现成的sql命令,我们可以在mysql提示符中直接这样加以执行。

代码语言:javascript
复制
mysql> source a.sql

这个文件名不用加引号。

或者也可以在bash中执行:

代码语言:javascript
复制
$mysql -h localhost -u root -p <a.sql> ans.txt

其中ans.txt是查询的结果,尖括号不可以省略,输出文件也不可以省略。通过这个方法我们就能把执行结果写入文件了。

存储过程

存储过程感觉就是一种函数,可以执行一些简单的逻辑,封装了零零散散的SQL语句。

修改标志

在创建过程之前我们需要修改下语句的结束标志,因为过程本身是一条SQL语句,但是过程又是由多条SQL语句组成的,这样我们就无法判断过程的结束标志了。因此我们需要修改下外层的结束标志,默认的结束标志是";",我们可以如下修改成其他的标志:

代码语言:javascript
复制
mysql> delimiter $

这样SQL语句的结束标志就标称了"$",这样我们就可以在过程内部仍然用";"作为单个语句的结束标志了。不过最后我们还是要记得把他修改回常用的标志“;”;

创建过程

代码语言:javascript
复制
mysql>create procedure mypro()
    ->begin
    ->select * from mytable;
    ->end$

这样我们就创建了一个简单的过程mypro。这个过程是数据库级的,因此他是归属于我们当前选择的数据库的。

执行过程

代码语言:javascript
复制
mysql> call mypro()

call下即可。

操作语言

过程中我们经常会用到选择或循环之类的控制语句,这些东西的语法类似pascal,具体用到的时候查下即可,这里不做解释。

查看和删除过程

当然,我们需要对过程进行管理:

查看当前数据库中的过程:

代码语言:javascript
复制
mysql> select `name` from mysql.proc where db = 'your_db_name' and `type` = 'PROCEDURE';

把your_db_name换成自己的数据库名即可。

删除某个过程:

代码语言:javascript
复制
mysql> drop procedure mypro;

参考资料

MySQL语法大全_自己整理的学习笔记 MySQL用文本方式将数据装入一个数据库表 MySQL存储过程详解 mysql 存储过程

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 登陆和退出
  • 选择数据库和表
  • 增删查改
  • 批处理
  • 存储过程
  • 参考资料
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档