linux环境安装mysql,以及mysql基本的终端操作命令

摘要:
Sql语句可用于操作关系数据库。
linux环境下安装mysql服务器、客户端
mysql简单的终端操作指令(使用数据库、简单的增删改查和备份恢复)
1 SQL:

Structured Query Language
结构化查询语言。
运用sql语句,可以对关系型数据库进行操作。
目前常见的关系型数据库有:
MySQL
oracle
SQL Server
sqlite




2 sql语句主要分为:
DQL:数据查询语言 select
DML:数据操作语言(增删改) insert、update、delete
TPL:事物处理语言 begin、transaction、commit、rollback
DCL: 数据控制语言 grant、revoke
DDL: 数据定义语言 create、drop
CCL: 指针控制语言 declare、cursor




3 在linux系统中安装MySQL
3.1 安装服务器端:
服务器用于接收客户端的请求,执行sql语句和管理数据库

终端执行命令来安装mysql的服务器:
sudo apt-get install mysql-server

终端开启mysql服务器的服务:
sudo service mysql start

停止服务:
sudo service mysql stop

重启服务:
sudo service mysql restart

3.2 安装客户端:
终端命令:
sudo apt-get install mysql-client

查看帮助文档:
mysql --help

客户端连接mysql服务器:
mysql -u 用户名 -p 密码
或者: mysql -u 用户名 -p 等待提示密码

连接成功后退出连接:
quit;
或者 exit;


4 linux下mysql命令行基本操作:
4.1 登录:
登录mysql: mysql -u 用户名 -p 密码
退出登录: quit; 或者 exit;

登陆后:
查看版本: select version();
查看当前sql服务器时间: select now();

修改输入提示符:
默认的输入提示符为 mysql>
prompt D 修改为当前完整时间
prompt d 修改为当前数据库名称
prompt u 使用用户名
prompt h 使用主机名称
也可以自己指定:
prompt python> 将输入提示符修改为 python>


4.2 数据库层次操作(确保登录客户端):

查看所有数据库:
show databases;

使用数据库:
use 数据库名;

查看当前使用数据库:
select database();

创建数据库:
create database 数据库名;

删除数据库:
drop database 数据库名;

查看当前已有数据库的创建语句:
show create database 数据库名;

4.3 数据表层次操作(确保使用数据库):
查看当前库中所有表:
show tables;

查看表结构:
desc 表名;

创建表:[]内的内容可以没有 也可以有
create table 表名(
字段1 类型 [约束],
字段2 类型 [约束],
字段3 类型 [约束],
字段4 类型,
字段5 类型
[, 主键或外键约束 ]
);
  例如: 创建一个表students,里面包括id,name,gender
create table students(
id int unsigned primary key auto_increment,
              -- id 无符号整数 主键 自动增长

name varchar(20) not null default "",
              -- name 可变长度字符串 非空 默认""

gender enum("男", "女","女博士","保密") default "保密"
              -- gender 枚举类型 只能是这几个值 默认保密

);

查看已有表的创建语句:
show create table 表名;

修改表:
添加字段:
alter table 表名 add 字段名 类型;

修改字段名:
alter table 表名 change 原字段 新字段名 约束;

修改字段类型和约束:
alter table 表名 modify 字段名 类型 约束;

删除字段:
alter table 表名 delete 字段名;

删除表:
drop table 表名;

4.4 表的简单增删改查语句:
增加数据:[] 内的内容可以省略
全插入:
insert [into] 表名 values( 值1, 值2 ,值3.... ,值n );
          -- 要求值和字段一一对应,所有字段都被赋值

也可以插入多条数据,values之间用,隔开:
insert [into] 表名 values( 值1, 值2 ,值3.... ,值n ),( 值1, 值2 ,值3.... ,值n );

部分插入:
insert [into] 表名 (列1,列2) values( 值1,值2 );
         -- 给指定的字段添加值,值和字段一一对应

也可以插入多条数据:
insert [into] 表名 (列1,列2) values( 值1,值2 ),( 值1,值2 ),( 值1,值2 );

查询数据:
查询所有列:
select * from 表名;

查询指定列:
select 列1,列2,列3 from 表名;

按条件查询:
select 列1,列2 from 表名 where 条件;
比如:
select * from students where id = 1;
            -- 查询students表中id是1的数据


修改数据:
修改表中所有数据:
update 表名 set 列1 = 值1 , 列2 = 值2 ... ;

指定修改数据:
update 表名 set 列1 = 值1 , 列2 = 值2 ... where 条件 ;
例如:
update students set name = "哈哈" where id = 1;
修改students表中id是1 的 数据 name改为哈哈

删除数据:
清空表内数据:
delete from 表名;

删除部分数据:
delete from 表名 where 条件;
例如:
delete from students where id = 1;
删除students表中 id 为1 的数据

逻辑删除(本质是修改):
update 表名 set isdelete = 1 where 条件


4.5 数据库备份和恢复:
备份:
mysqldump -u root -p 数据库名 > 备份文件名称.sql;

恢复:
连接mysql,创建一个新的数据库后退出连接执行如下命令:
mysql -u root -p 新数据库名 < 备份文件名.sql


5 mysql中的数据类型和约束
数据类型:
整数: int 、 bit
小数: decimal(5,2) 共存5位,小数占2位
字符串: varchar(20) 可变长度字符串,最多能存20位
char(5) 固定长度字符串,不足5位自动补空格
text 大文本 字符大于4000时推荐使用
日期时间:date、time、datetime
枚举类型(enum)

对于图片 音频 视频等文件 不存处在数据库中,而是上传到某个服务器,然后在标中存这个文件的保存路径


数值类型(常用):
类型 字节大小 有符号范围(Signed) 无符号范围(Unsigned)
TINYINT 1 -128 ~ 127 0 ~ 255
SAMLLINT 2 -32768 ~ 32767 0 ~ 65535
MEDIUMINT 3 -8388608 ~ 8388607 0 ~ 16777215
INT/INTEGER 4 -2147483648 ~2147483647 0 ~ 4294967295
BIGINT 8 -9223372036854775808 ~ 9223372036854775807 0 ~ 18446744073709551615

字符串:
类型 字节大小 示例
CHAR 0-255 类型:char(3) 输入 'ab', 实际存储为'ab ', 输入'abcd' 会报长度过长的错误
VARCHAR 0-255 类型:varchar(3) 输 'ab',实际存储为'ab', 输入'abcd',会报长度过长的错误
TEXT 0-65535 大文本

日期时间类型:
类型 字节大小 示例
DATE 4 '2020-01-01'
TIME 3 '12:29:59'
DATETIME 8 '2020-01-01 12:29:59'
YEAR 1 '2017'
TIMESTAMP 4 '1970-01-01 00:00:01' UTC ~ '2038-01-01 00:00:01' UTC

约束:
主键: primary key
非空: not null
唯一: unique
默认: default
外键: foreign key


免责声明:文章转载自《linux环境安装mysql,以及mysql基本的终端操作命令》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Nacos Config 多环境的配置javascript自动随机跳转代码下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

php插入数据含有特殊符号的处理方法

我们在向mysql写入数据时,比如: mysql_query(”update table set `title`=’kuhanzhu’s blog’”);  http://www.cnblogs.com/xiaochaohuashengmi/archive/2010/05/09/1731415.html   那就会出错。同asp时一样,数据库都会对单引...

tcp_tw_recycle参数引发的数据库连接异常

【问题描述】 开发反馈有个应用在后端数据库某次计划性重启后经常会出现数据库连接异常问题,通过监控系统的埋点数据,发现应用连接数据库异常有两类表现:   其一:连接超时   131148.00ms Tomcat Connection Pool   其二:连接耗时过长   DAL.getConnectionCost 64018ms 【问题分析】 通过监控数据汇...

Linux(CentOS)用户修改密码有效期

1、 先查看密码过期时间: [root@01 ~]# chage -l testuser Last password change : Jul 10, 2017 Password expires : Oct 08, 2018 Password inactive : never Account expires : never...

PG-表空间管理

2.5 表空间 PostgreSQL中的表空间允许数据库管理员在文件系统中定义用来存放表示数据库对象的文件的位置。一旦被创建,表空间就可以在创建数据库对象时通过名称引用。 表空间也是数据库集簇的一部分 并且不能被视作数据文件的一个自治集合。 它们依赖于包含在主数据目录中的元数据,并且因此不能被附加到一个不同的数据库集簇或者单独备份。 当初始化数据库集簇($...

基于ABP的应用执行Update-Database出现异常的解决办法

今天在QQ群中看到有网友在更新数据库执行Update-Database时出现下面的错误: 为了能让搜索引擎搜索到,特意加上该错误的文字说明: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: SQL Networ...

复制MySQL数据库A到另外一个MySQL数据库B(仅仅针对innodb数据库引擎)

方案一:(不用太大的变化my.ini文件) copy 原数据库A中的   数据库(database)  ib_logfile1  ib_logfile0   ibdata1; 关闭目的数据库B;  备份目的数据库B中的  ib_logfile1  ib_logfile0   ibdata1 三个文件,防止更改后不能使用数据库; 将copy 来的原数据库A...