mysql 命令行操作命令

  • mysql 安装
  • 连接
  • 导入数据
  • 导出数据
  • crud
  • 常用函数:count, avg, max, min, length

RDBMS 关系型数据库管理系统

图:

mysql 安装

linux

服务端

sudo apt-get install mysql-server

sudo service mysql start 启动数据库服务器

ps ajx|grep mysql 查看服务器是否启动

sudo service mysql stop

sudo service mysql restart

位置:/var/lib/mysql

mysql配置位置:/etc/mysql

mysql默认是存储在/var/lib/mysql目录下的

mysql> show variables like ‘%data%’;

命令行客户端

sudo apt-get install mysql-client

启动数据库

mysql -u root -pmysql 密码是mysql

命令行连接

mysql -uroot -p

回车后输入密码,当前设置的密码为mysql

退出数据库:

ctrl+d或

quit 或者 exit

windows

windows安装mysql:

https://blog.csdn.net/zhouzezhou/article/details/52446608

注意管理环境变量添加后才可以用net start mysql80,且管理员身份执行 (mysql80是安装时取的名字)

设置的是开机启动

navicat连接不上:ALTER USER ‘root‘@‘localhost‘ IDENTIFIED WITH mysql_native_password BY ‘yourpassword‘

注意:1.可以不用引号,2.可能需要 flush privileges

连接

远程连接不上,常见处理:

  1. ping不通
  2. 该服务host仅localhost
  3. 有密码等权限问题

    curd

关系型数据库核心元素

数据行(记录)

数据列(字段)

数据表(数据行的集合)

数据库(数据表的集合) ==== 整个Excel 文件就好比一个数据库,一个sheet 就 好比一个 数据表

常用数据类型如下:

整数:int,bit

小数:decimal

字符串:varchar,char

日期时间: date, time, datetime

枚举类型(enum)

约束:

-- auto_increment表示自动增长

-- not null 表示不能为空

-- primary key 表示主键

-- default 默认值

登录成功后,输入如下命令查看效果

查看版本:select version();

显示当前时间:select now();

  • 数据库

    查看所有数据库 show databases;

    使用数据库 use 数据库名;

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

    创建数据库 create database 数据库名 charset=utf8; 等号可以不写

    查看创建数据库的语句 show create database xxx;

    删除数据库/表 drop database 数据库名; drop table 表名

    删除行(表结构还在) Delete from 表名 where xxx ; delete from 表名 或 delete * from 表名

    删除表内的数据(表结构还在) truncate table 表名 = delete from 表名

    删除数据的速度,一般来说: drop> truncate > delete

    使用场合:

    当你不再需要该表时, 用 drop;

    当你仍要保留该表,但要删除所有记录时, 用 truncate;

    当你要删除部分记录时(always with a where clause), 用 delete

  • 数据表

    查看当前数据库中所有表 show tables;

    创建表 (字段 ) create table 数据表名字 (字段1 类型 约束,字段2 类型 约束...);

    查看表结构 desc 数据表的名字; 查看表的创建语句 show create table xxxx;

    查询classes表中所有的数据 select * from xxxx;

    修改表-添加字段 alter table 表名 add 列名 类型; # 列名不可少

    修改表-修改字段:类型或约束 alter table 表名 modify 列名 类型及约束;

    修改表-修改字段:重命名 alter table 表名 change 原名 新名 类型及约束;

    修改表-删除字段

    alter table 表名 drop 列名(字段);

    删除表 drop table 表名

    数据 记录 增删改查 (curd) 代表创建(Create)、更新(Update)、读取(Retrieve)和删除(Delete)

    增加 记录(插入数据,行) insert into xxxx values(0, "mike", 18, 1.45, "保密", 2); >>>>配合 desc 使用, 对应table的字段 全部都要写 主键字段 可以用 0 null default 来占位

部分插入 insert into 表名(列1,...) values(值1,...);

insert into students(high) values(180.1);

多行插入

insert into students(name, high) values("李四", 180.1), ("王五", 1.22);

修改 update 表名 set 列1=值1,列2=值2... where 条件;

update students set age=18 where id=1;

删除

物理删除 delete from students where id=6;

逻辑删除 alter table students add is_delete bit default 0;

update students set is_delete=1 where id=1;

查询基本使用 select * from students;

一定条件的查询 select * from students where id>=1 and id<=4; ## 要有空格

查询指定列 select 列1,列2,... from 表名; (同样可以加where)

字段的顺序 列2 列1会对应 可以使用as为列或表指定别名

select name as 姓名, id as 学号 from students where id>=1 and id<=4;

select students.name, students.age from students; #

select s.name, s.age from students as s; ####

消除重复行

-- distinct 字段

-- 查询students表中所有的不重复的性别

select gender from students;

select distinct gender from students;

条件查询

比较运算符

select * from students where age>18;

select id,name,gender from students where age>18;

逻辑运算符

select * from students where age >=18 and age <= 28;

select * from students where age >=18 or height >= 180;

select * from students where not age<=18 and gender=2;

select * from students where not (age<=18 and gender=2);

模糊查询

-- like

-- % 替换0个或者多个

-- _ 替换1个

select * from students where name like "小%";

select * from students where name like "%小%";

select * from students where name like "";

select * from students where name like "%%";

范围查询

in (1, 3, 8)表示在一个非连续的范围内

select name,age from students where age in (18, 34);

select name,age from students where age not in (18, 34);

between ... and ...表示在一个连续的范围内

select name,age from students where age between 18 and 34;

select name,age from students where age not between 18 and 34;

失败的select * from students where age not (between 18 and 34);

空判断

select * from students where height is null;

判非空is not null

select * from students where height is not null;

排序

order by 字段 asc从小到大排列,即升序 ascend default;

desc从大到小排序,即降序 descend

select * from students where (age between 18 and 34) and gender=1 order by age;

order by 多个字段

select * from students where (age between 18 and 34) and gender=2 order by height desc, age asc;

聚合函数

count()统计列数,count(字段)一样

select count() from students where gender=1;

select count() as "男性" from students where gender=1;

最大值 max 最小值 min 求和 sum 平均值 avg

select max(age) from students;

select sum(age)/count() from students;

select avg(age) from students;

四舍五入 round(123.23 , 1) 保留1位小数

select round(avg(age), 2) from students;

分组

select gender from students group by gender;

失败select * from students group by gender;

select gender, count() from students group by gender;

select gender, count() from students where gender=1 or gender=2 group by gender;

--group_concat(...)

select gender, group_concat(name) from students group by gender;

select gender, group_concat(name, id) from students group by gender;

select gender, group_concat(name, "%", id) from students group by gender;

--having

select gender, group_concat(age) from students group by gender having avg(age) > 30;

select gender, group_concat(name, age) from students group by gender having avg(age) > 30;

select gender, group_concat(name) from students group by gender having count(*) > 2;

分页

-- limit start, count 从第0行开始查 limit 3 ; >>>limit 0, 3 ;

select * from students limit 0, 3;

select * from students limit 4, 2;

select * from students where gender=2 order by height desc limit 0, 2;

连接查询

-- inner join ... on

-- select ... from 表A inner join 表B;

select * from students inner join classes on students.cls_id=classes.id;

select * from students inner join classes on students.cls_id=classes.id;

select s.name, c.name from students as s inner join classes as c on s.cls_id=c.id;

select s., c.name from students as s inner join classes as c on s.cls_id=c.id;

select c.name, s.from students as s inner join classes as c on s.cls_id=c.id order by c.id, s.id;

select * from students left join classes on students.cls_id=classes.id;

-- 查询没有对应班级信息的学生

select * from students left join classes on students.cls_id=classes.id where/having classes.id is null;

自关联

select * from areas where pid is null;

select count() from areas where pid is null;

select p.atitle,c.atitle from areas as p inner join areas as c on c.pid=p.aid where p.atitle="广东省";

子查询

select from students where age=(select max(age) from students);

-- 标量子查询

select * from students where height>(select avg(height) from students);

-- 列级子查询

select * from students where cls_id in (select id from classes);

事务四大特性(简称ACID)

事务是由一组SQL语句组成的逻辑处理单元, 银行转帐就是事务的一个典型例子。

原子性(Atomicity)

不被中断

一致性(Consistency)

总数一定

隔离性(Isolation)

对方看不到

持久性(Durability)

数据被保存

图形化界面客户端navicat

进入解压后的文件目录 运行 ./start_navicat

外键对查询没影响, 插入数据时影响效率

ctrl + shift + t 终端开标签

分组一般和聚合函数使用;

where having

order by

limit 最后

原文地址:https://www.cnblogs.com/bruspawn/p/10330982.html

时间: 2025-01-17 04:29:05

mysql 命令行操作命令的相关文章

mysql命令行下创建和删除索引简介

mysql命令行下创建和删除索引简介: mysql中创建索引可以使用CREATE TABLE语句,也可以用CREATE INDEX或ALTER TABLE来给表增加索引.索引的删除可以使用ALTER TABLE或DROP INDEX语句来实现. (1)使用ALTER TABLE语句创建索引.语法如下:alter table table_name add index index_name (column_list) ;alter table table_name add unique (colum

mysql命令行导入sql脚本中文变问号问题

之前一直用工具连接mysql虽然小问题不断也都无伤大雅,最近做金融云项目,只能通过服务器的内网访问数据库,也就是说只能在linux下通过命令行访问,在导入中文的时候发现都变成问号了,经过查询资料解决,特此记录一下思路. 1.检查sql脚本文件是否unicode编码,打开查看是脚本文件中中文是否能正常显示. 2.检查所建好的数据库是否采用utf8编码. 3.在mysql命令行下执行status检查Server characterset和Client characterset编码是否一致(我就是这一

如何使用mysql命令行

现在向大家介绍mysql命令行下,从数据库的建立到表数据的删除全过程,希望对网友有所帮助 方法/步骤 1.登陆mysql 打cmd命令终端,如果已经添加了mysql的环境变量,可以直接使用命令 mysql -uroot 直接回车,之后按提示输入密码, 如果未添加mysql的环境变量,可以切换到mysql的安装目录下的bin目录,再使用 mysq -uroot 你也可以手动为mysql添加环境变量.这里就不介绍怎么添加环境变量的方法了 密码输入正确之后,就会出现“Welcome to the My

mysql命令行参数

一,mysql命令行参数 Usage: mysql [OPTIONS] [database] //命令方式 -?, --help //显示帮助信息并退出 -I, --help //显示帮助信息并退出 --auto-rehash //自动补全功能,就像linux里面,按Tab键出提示差不多,下面有例子 -A, --no-auto-rehash //默认状态是没有自动补全功能的.-A就是不要自动补全功能 -B, --batch //ysql不使用历史文件,禁用交互 (Enables --silent

mysql命令行,多行命令时如何取消/返回修改前边的命令

mysql命令行中执行多行命令时,如果前边输入的命令发生错误,是无法返回修改的,但是可以通过输入\c来取消前边的输入,但是这时如果前边输入的东西很多,直接取消又很可惜的话,可以通过\p来打印出前边的命令,复制下来去修改,然后输入\c取消来重新输入命令. Example 1 2 3 4 5 6 7 8 9 10 11 12 13 mysql> select 8 from a     -> where 1=1     ->  and 1=0     -> \p #输入\p后,打印出了前

Mysql命令行基本操作

本文记录的是windows7系统下Mysql的命令行基本操作. 一.Mysql启动与登录 1. Mysql启动: 通过运行mysql安装目录下的/bin/mysqld.exe文件来启动Mysql服务.在命令行中进入mysql安装目录下的bin目录,执行命令: mysqld --defaults-file="C:\Program Files\MySQL\MySQL Server X.Y\my.ini"(指定配置文件,配置文件的位置根据具体情况而定) 即可启动mysql服务.为了以后开启m

MySQL命令行导出数据库

MySQL命令行导出数据库:1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录如我输入的命令行:cd C:\Program Files\MySQL\MySQL Server 4.1\bin(或者直接将windows的环境变量path中添加该目录) 2,导出数据库:mysqldump -u 用户名 -p 数据库名 > 导出的文件名 如我输入的命令行:mysqldump -u root -p news > news.sql   (输入后会让你输入进入MySQL的密码)(

MySql命令行无法显示中文

好烦遇到了,遇到MySql命令行无法显示中文问题????? show variables like 'char%';//显示字符集 set names utf8;//设置字符集 describer tablename//显示tablename表中的简单属性 show full columns from tablename//显示tablename表中的字段属性 show create table tablename//显示创建tablename的代码 正在寻找解决办法...... 未完待续...

MYSQL 命令行显示乱码 解决方案

中文乱码是因为编码集不支持,所以要改变编码 先查看下设置的编码 使用如下命令 show variables like 'character%'; 在 mysql.conf (Ubuntu mysql5.5)中的 [client]区域加上 default-character-set = utf8 在[mysqld]区域加上 character_set_server = utf8 重启服务 原文地址:MYSQL 命令行显示乱码 解决方案