Linux访问MySQL数据库(包含实验案例)

这篇具有很好参考价值的文章主要介绍了Linux访问MySQL数据库(包含实验案例)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、访问MySQL数据库。

1.1、登录到MySQL服务器

        经过安装后的初始化过程,MySQL数据库的默认管理员用户名为"root",密码为空

[root@yang ~]# mysql -u root  //"-u"选项用于指定认证用户

        有密码的情况下,使用"-p"选项来进行密码校验。

[root@yang ~]# mysql -u root -p 
Enter password: 

1.2、执行MySQL操作语句

        验证成功以后将会进入提示符为"MySQL>"的数据库操作环境,用户可以输入各种操作语句对数据库进行管理。每条MySQL操作语句以分号";"表示结束,输入时可以不区分大小写。

        例如,以用户名root登录到"mysql>"环境后,执行"status;"语句可以查看当前数据库服务的基本信息。

[root@yang ~]# mysql -u root

mysql> status;
--------------
mysql  Ver 14.14 Distrib 5.6.36, for Linux (x86_64) using  EditLine wrapper

Connection id:		2
Current database:	
Current user:		root@localhost
SSL:			Not in use
Current pager:		stdout
Using outfile:		''
Using delimiter:	;
Server version:		5.6.36 Source distribution
Protocol version:	10
Connection:		Localhost via UNIX socket
Server characterset:	utf8
Db     characterset:	utf8
Client characterset:	utf8
Conn.  characterset:	utf8
UNIX socket:		/tmp/mysql.sock
Uptime:			8 min 13 sec

Threads: 1  Questions: 7  Slow queries: 0  Opens: 67  Flush tables: 1  Open tables: 60  Queries per second avg: 0.014
--------------

1.3、退出"mysql>"操作环境

        在"mysql>"操作环境中,执行"exit"或"ouit"命令可以退出mysql命令工具,返回原来的shell环境。

mysql> exit
Bye
[root@yang ~]# 

2、使用MySQL数据库

2.1、查看当前服务器中有哪些库

        show databases 语句:用于查看当前MySQL服务器中包含的库,默认包含(test、mysql、information_schema、performance_schema)

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.00 sec)

2.2、查看当前使用的库中有哪些表

        show tables 语句:用于查看当前所在的库中包含的表

        use语句:切换到所使用的库

mysql> use bdqn
Database changed
mysql> show tables;
+----------------+
| Tables_in_bdqn |
+----------------+
| benet          |
+----------------+
1 row in set (0.00 sec)

        MySQL数据库的数据文件存放在/usr/local/mysql/data目录下,每个数据库对应一个子目录,用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为".frm"、".myd"、".myi"

[root@yang bdqn]# cd /usr/local/mysql/data/bdqn/
[root@yang bdqn]# ls
benet.frm  benet.ibd  db.opt

2.3、查看表的结构

        describe 语句:用于显示表的机构,即组成表的各字段(列)的信息

mysql> describe bdqn.benet;
+--------+----------+------+-----+---------+-------+
| Field  | Type     | Null | Key | Default | Extra |
+--------+----------+------+-----+---------+-------+
| user   | char(15) | NO   |     | NULL    |       |
| passwd | char(18) | NO   |     | NULL    |       |
+--------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

3、创建及删除库和表

3.1、创建新的库

        create database 语句:用于创建一个新的库,需指定数据库名称作为参数。

mysql> create database auth;  //创建一个名为auth的数据库

mysql> show databases;  //查看包含哪些数据库
+--------------------+
| Database           |
+--------------------+
| information_schema |
| auth               |
| bdqn               |
| mysql              |
| performance_schema |
| test               |
+--------------------+
6 rows in set (0.00 sec)

        刚创建的数据库是空的,其中不包含任何表,在/usr/local/mysql/data目录下会自动生成一个与新建的库名相同的文件夹。

[root@yang bdqn]# cd /usr/local/mysql/data/
[root@yang data]# ls
auth  auto.cnf  bdqn  ibdata1  ib_logfile0  ib_logfile1  localhost.localdomain.err  mysql  performance_schema  test  yang.err  yang.pid

3.2、创建新的表

        create table 语句:用于在当前库中创建新的表

mysql> create table users (user_name char(16) not null, user_passwd char(48) default '', primary key (user_name));

mysql> show tables;
+----------------+
| Tables_in_auth |
+----------------+
| users          |
+----------------+
1 row in set (0.00 sec)

3.3、删除一个数据表

        drop table 语句:用于删除库中的表

mysql> drop table auth.users;
Query OK, 0 rows affected (0.00 sec)

3.4、删除一个数据库

        drop database 语句:用于删除指定的库

mysql> drop database auth;
Query OK, 0 rows affected (0.00 sec)

4、管理表中的数据记录

4.1、插入数据记录

        insert into 语句:用于向表中插入新的数据记录。password('123456')表示将密码加密

mysql> insert into auth.users (user_name,user_passwd) values('lisi',password('123456'));
Query OK, 1 row affected (0.00 sec)

mysql> select * from auth.users;  //查看数据表中的内容
+-----------+-------------------------------------------+
| user_name | user_passwd                               |
+-----------+-------------------------------------------+
| lisi      | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+-----------+-------------------------------------------+
1 row in set (0.00 sec)

5、数据用户授权

5.1、授予权限

        grant 语句:专门用来设置数据库用户的访问权限,当指定的用户名不存在时,grant语句将会创建新的用户,否则,grant语句用于修改用户信息 


grant  权限列表 on 库名.表名 to 用户名@来源地址 [ identified by '密码' ]


权限列表:用于授予权限。select、insert、update,使用"all"表示所有权限

库名.表名:用于指定授权的对象,"auth.*"表示auth数据库中的所有表

用户名@来源地址:用于指定访问的对象。可以是IP地址、域名。也可以是"%"通配符,"%.bdqn.com"、"192.168.1.%"表示某个区域或网段内的所有地址

identified by:用于设置密码。若省略则用户的密码为空

        创建一个名为xiaoqi的数据库用户,允许本地访问数据库auth下的所有表,密码为123 

mysql> grant select on auth.* to 'xiaoqi'@'localhost' identified by '123';
Query OK, 0 rows affected (0.00 sec)

//使用xiaoqi数据库用户登录
[root@yang ~]# mysql -u xiaoqi -p
Enter password: 

//验证权限
mysql> select * from auth.users;
+-----------+-------------------------------------------+
| user_name | user_passwd                               |
+-----------+-------------------------------------------+
| lisi      | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+-----------+-------------------------------------------+
1 row in set (0.00 sec)

//访问其他数据库则没有权限
mysql> select * from mysql.user;
ERROR 1142 (42000): SELECT command denied to user 'xiaoqi'@'localhost' for table 'user'

 5.2、查看权限

        show grants 语句:专门用于查看数据库用户的授权信息,通过for可以指定查看的用户

linux访问mysql数据库,Linux高级管理,linux

 5.3、撤销权限

        revoke 语句:用于撤销指定用户的数据库权限。撤销后的用户仍然可以连接到mysql服务器,但将被禁止执行对应的数据库操作

mysql> revoke all on auth.* from 'xiaoqi'@'localhost';
Query OK, 0 rows affected (0.00 sec)

mysql> show grants for 'xiaoqi'@'localhost';
+---------------------------------------------------------------------------------------------------------------+
| Grants for xiaoqi@localhost                                                                                   |
+---------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'xiaoqi'@'localhost' IDENTIFIED BY PASSWORD '*23AE809DDACAF96AF0FD78ED04B6A265E05AA257' |
+---------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

6、实验案例

1、为MySQL数据库的root用户设置密码,删除用户名、密码为空的用户记录

2、新建名为"bdqn"的库,授权用户rundb从本机访问,具有所有操作权限

3、以rundb用户登录,在bdqn库中创建stuinfo表,并录入如下数据

linux访问mysql数据库,Linux高级管理,linux

1、更改数据库mysql中的user表,将root的密码更改为123,并刷新用户授权信息 

mysql> use mysql
Database changed
mysql> update mysql.user set password=password('123') where user='root';
Query OK, 4 rows affected (0.00 sec)
Rows matched: 4  Changed: 4  Warnings: 0

mysql> flush privileges;  //刷新用户授权信息
Query OK, 0 rows affected (0.00 sec)

 2、创建一个名为bdqn的数据库,并添加一个rundb数据库用户,授予所有权限以本机访问。

mysql> create database bdqn;
Query OK, 1 row affected (0.00 sec)

mysql> grant all on bdqn.* to 'rundb'@'localhost' identified by '123';
Query OK, 0 rows affected (0.00 sec)

3、在bdqn数据库中新建stuinfo表,并录入数据。文章来源地址https://www.toymoban.com/news/detail-858856.html

mysql> create table stuinfo 
    -> (姓名 nvarchar(10) not null primary key, 
    -> 性别 nvarchar(2) not null, 
    -> 年龄 int not null,
    -> 联系电话 bigint not null,
    -> Email地址 nvarchar(50)
    -> );


mysql>  insert into stuinfo (姓名,性别,年龄,联系电话,Email地址)                                                                                                                    values('张无忌','男','19','17512345678','wuji.zhang@mingchao.org');


mysql>  insert into stuinfo (姓名,性别,年龄,联系电话,Email地址)
    ->  values('白居易','男','24','17587654321','juyi.bai@tangchao.org');


mysql>  insert into stuinfo (姓名,性别,年龄,联系电话,Email地址)
    ->  values('蓝采和','女','21','17555201314','caihe.lan@wudaisong.org');


mysql> select * from stuinfo;
+-----------+--------+--------+--------------+-------------------------+
| 姓名      | 性别   | 年龄   | 联系电话     | Email地址               |
+-----------+--------+--------+--------------+-------------------------+
| 张无忌    | 男     |     19 |  17512345678 | wuji.zhang@mingchao.org |
| 白居易    | 男     |     24 |  17587654321 | juyi.bai@tangchao.org   |
| 蓝采和    | 女     |     21 |  17555201314 | caihe.lan@wudaisong.org |
+-----------+--------+--------+--------------+-------------------------+

到了这里,关于Linux访问MySQL数据库(包含实验案例)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Mysql判断某个数据库中是否包含某个表,与pymysql工具函数

    查看某个数据库中的全部表: 因此查看某个库中的某个表可以使用: 在pymysql中,可以写一个简单的工具函数,用于查询某个数据库中是否包含某个表: 这里的_query函数请参考博客:python使用pymysql总是超时的解决方案

    2024年02月09日
    浏览(62)
  • python 实现学生信息管理系统+MySql 数据库,包含源码及相关实现说明~

    1、系统说明 python 编写的学生信息管理系统+MySQL数据库,实现了增删改查的基本功能。 2、数据库说明 本人使用的是 MySQL8.0 版本 数据库端口号为:3306 数据库用户名是:root 数据库名称是:practice 建立的表是:students 3、系统功能 增加学生信息 删除学生信息 修改学生信息 查

    2024年02月11日
    浏览(54)
  • MySQL数据库实验三 MySQL查询

    一、实验项目: MySQL查询。 二、实验目的 掌握MySQL的查询操作。 三、实验内容 (一): 1、查询lineitem表中商品编号(productid)和单价(unitprice),要求消除重复行。 2、计算lineitem表中每条记录的商品金额。 3、显示orders表单笔高于200元的客户号(userid)、成交金额(total

    2024年02月11日
    浏览(56)
  • 实例讲解C++连接各种数据库,包含SQL Server、MySQL、Oracle、ACCESS、SQLite 和 PostgreSQL、MongoDB 数据库

      C++ 是一种通用的编程语言,可以使用不同的库和驱动程序来连接各种数据库。以下是一些示例代码,演示如何使用 C++ 连接 SQL Server、MySQL、Oracle、ACCESS、SQLite 和 PostgreSQL、MongoDB 数据库。 连接 SQL Server 数据库 要使用 C++ 连接 SQL Server 数据库,可以使用 Microsoft 的 ADODB 库。以

    2024年02月05日
    浏览(66)
  • 数据库系统原理及MySQL应用教程实验四MySQL数据库表数据的查询操作

    1.掌握SELECT 语句的基本语法格式。 2.掌握SELECT 语句的执行方法。 3.掌握SELECT 语句的 GROUP BY 和 ORDER BY 子句的作用。 验证性实验:在公司的部门员工管理数据库的bumen表和yuangong表上进行信息查询。 设计性试验:将在student表和score表上进行查询。 ( 一 ) 验证性实验 在

    2024年02月05日
    浏览(57)
  • MySQL数据库 实验报告(一)

    实验报告(一) 1、实验目的 (1)掌握系统数据类型的特点和功能 (2)掌握创建、修改表结构的方法 (3)掌握数据添加的方法 2、实验预习与准备 (1)MYSQL中创建数据库的命令 (2)表结构的创建、修改和删除 (3)MYSQL导入导出表数据的方式 (4)添加数据的SQL命令 3、实

    2024年02月05日
    浏览(59)
  • MySQL数据库设计作业 ——《网上书店系统》数据库设计实验报告

    普通用户:可以进行最基础的登陆操作,可浏览图书、按类别查询图书、查看 图书的详细信息,还可以注册成为会员。 会员:需要填写详细信息(真实姓名、性别、手机号、地址、邮箱等),可浏览图书、按类别查询图书、查看图书的详细信息,在此基础上,还可以订购图

    2024年02月04日
    浏览(77)
  • mysql数据库实验实训6,数据视图(详细)

    1、掌握视图功能和作用 2、掌握视图创建和管理办法 对YGGL数据库完成以下视图操作: 1、在员工管理数据库YGGL中创建视图Emp_view1,包含所有男员工的员工编号、姓名、工作年限和学历: 代码: mysql create or replace view Emp_view1 - as select 员工编号,姓名,工作年限,学历 - from employee

    2024年02月07日
    浏览(69)
  • Node.js程序如何访问MySQL数据库呢?Sequelize操作MySQL数据库详解

    当我们安装好MySQL后,Node.js程序如何访问MySQL数据库呢? 访问MySQL数据库只有一种方法,就是通过网络发送SQL命令,然后,MySQL服务器执行后返回结果。 我们可以在命令行窗口输入mysql -u root -p,然后输入root口令后,就连接到了MySQL服务器。因为没有指定–host参数,所以我们连

    2023年04月08日
    浏览(46)
  • 数据库原理及应用(MySQL版)MySQL实验指导参考答案(实验一到实验八)

    实验二 实验三 实验五 实验六 实验七 实验八

    2024年02月04日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包