Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >mysql基本sql语句大全(基础用语篇)_mysql查询语句汇总

mysql基本sql语句大全(基础用语篇)_mysql查询语句汇总

作者头像
全栈程序员站长
发布于 2022-10-03 09:17:35
发布于 2022-10-03 09:17:35
3K0
举报

大家好,又见面了,我是你们的朋友全栈君。

1.数据库存储引擎

mysql> show variables like ‘%storage_engine%’; #查看mysql当前默认的存储引擎

mysql> show engines; #查看存储引擎

InnoDB存储引擎:默认引擎,最常用的。

InnoDB是事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定和外键;InnoDB是默认的

MySQL引擎 InnoDB特点: 支持事务处理,支持外键,支持崩溃修复和并发控制。如果需要对事务的完整性要求比较高(比如银行),要求实现并发控制(比如售票),那选择InnoDB有很大的优势。如果需要频繁的更新、删除操作的数据库,也可以选择InnoDB,因为支持事务的提交(commit)和回滚(rollback)。

默认的是InnoDB,但有时候我们需要使用其它引擎该怎么办?

mysql> create table t1(字段名,类型) engine=引擎; #创建的时候指定你想要的引擎

#如果你创建表的时候忘了指定引擎了,那它使用的就是默认的InnoDB,当然我们也可以修改引擎

mysql> ALTER TABLE 表名 ENGINE=引擎; #将该表修改指定为你想要使用的引擎

注意:在Mysql中,指令不分大小写,但是库名,表名之类的不属于与指令的是区分大小写的。

2.增删改查

1.创建库

mysql> create database 库名;

2.查看数据库中的所有库

mysql> show databases;

3.进入数据库

mysql> use 库名;

4.查看当前所在的库

mysql> select database();

创建表

必须先使用mysql> use 库名;语句进入某个库中,才能创建表

语法:

create table 表名(

字段名1 类型[(宽度) 约束条件],

字段名2 类型[(宽度) 约束条件],

字段名3 类型[(宽度) 约束条件]

)[存储引擎 字符集];

==在同一张表中,字段名是不能相同

==宽度和约束条件可选

==字段名和类型是必须的

=========================================================

1.创建表:

mysql> create table t1(id int, name varchar(20), age int);

字段 类型 字段 类型(长度), 字段 类型

2.查看有哪些表

mysql> show tables;

3.查看表结构:

mysql> desc 表名;

4.查看表里面的所有记录:

语法: select 内容 from 表名;

mysql> select * from t1;

*:代表所有内容

5.查看表里面的指定字段:

语法:select 字段,字段 from 表名;(可以查一个字段,也可以是多个,中间用逗号隔开)

mysql> select name,age from t1;

6.查看表的状态

mysql> show table status like ‘表名’\G

#\G表示查看的内容会一条记录一条记录显示。用的\G就不用添加分号了

7.修改表名称

方式一、语法:rename table 旧表名 to 新表名;

mysql> rename table t1 to t2;

Query OK, 0 rows affected (0.00 sec)

方式二、语法:alter table 旧表名 rename 新表名;

mysql> alter table t2 rename t3;

8.使用edit(\e)编辑——了解

mysql> \e #可以写新的语句,调用的vim编辑器,在里面结尾的时候不加分号,保存退出之后在加“;”

-> ;

9.删除表

mysql> drop table 表名;

10.删除库

mysql> drop database 库名;

3.约束

常见的约束条件

不分大小写:

PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录,不可以为空 UNIQUE + NOT NULL

FOREIGN KEY (FK) 标识该字段为该表的外键,实现表与表(父表主键/子表1外键/子表2外键)之间的关联

NULL 标识是否允许为空,默认为NULL。

NOT NULL 标识该字段不能为空,可以修改。

UNIQUE KEY (UK) 标识该字段的值是唯一的,可以为空,一个表中可以有多个UNIQUE KEY

AUTO_INCREMENT 标识该字段的值自动增长(整数类型,而且为主键)

DEFAULT 为该字段设置默认值

UNSIGNED 无符号,正数

1.主键

每张表里只能有一个主键,不能为空,而且唯一。

定义两种方式:

mysql> create table 表名(字段1 类型 primary key,字段2 类型); #在字段1的类型后面定义

mysql> create table 表名(字段1 类型,字段2 类型,primary key(字段1));# 在最后定义,并指定哪个字段

删除主键

mysql> alter table 表名 drop primary key;

2.索引

索引:当查询速度过慢可以通过建立优化查询速度,可以当作调优

index(key)每张表可以有很多列做index

创建索引:两种

mysql> create table 表名(字段1 类型 primary key,字段2 类型,index (字段2));

mysql> create table 表名(字段1 类型 primary key,字段2 类型,index 别名(字段2));

#给字段2做的索引并起别名

3.自增

auto_increment——–自增 (每张表只能有一个字段为自曾) (成了key才可以自动增长)

mysql> CREATE TABLE 表名 (

-> 字段1 类型 PRIMARY KEY AUTO_INCREMENT,

-> 字段2 类型,

-> 字段3 类型

-> );

4.表操作

1.添加新字段

alter table 表名 add 字段 修饰符;

mysql> alter table 表名 add 字段名 类型;#添加的字段

mysql> alter table 表名 add (字段1 类型,字段2 类型);#添加多个字段,中间用逗号隔开。

alter table 表名 add 添加的字段(和修饰) after name; #把添加的字段放到name后面

alter table 表名 add 添加的字段(和修饰) first; #把添加的字段放在第一个

2.修改名称、数据类型、修饰符

alter table 表名 change 旧字段 新字段 修饰符; #change修改字段名称,类型,约束,顺序

mysql> alter table 表名 change 旧字段 新字段 类型 after 字段1; #修改字段名称与修饰并放在字段1后面

3.修改字段类型,约束,顺序

alter table 表名 modify 字段 类型 修饰符; #modify 不能修改字段名称

mysql> alter table 表名 modify 字段 类型 after 字段名; #修改修饰并更换位置

4.删除字段

mysql> alter table 表名 drop 字段名; #drop 丢弃的字段。

插入数据

字符串必须引号引起来

记录与表头相对应,表头与字段用逗号隔开。

1.添加一条记录

insert into 表名(字段1,字段2,字段3,字段4) values(1,”yjssjm”,”man”,90);

注:添加的记录与表头要对应,

2.添加多条记录

mysql> insert into 表名(字段1,字段2,字段3,字段4) values(2,”yjssjm”,”woman”,19),

(3,”xiaoming”,”man”,20);

3.用set添加记录

mysql> insert into 表名 set 字段1=值1,字段2=值2,字段3=值3,字段4=值4;

4.更新记录

update 表名 set 修改的字段 where 给谁修改;

mysql> update 表名 set 字段1=值 where 字段2=值;

5.删除记录

1.删除单条记录

mysql> delete from 表名 where 字段1=值; #删除那个记录,等于几会删除那个整条记录

2.删除所有记录

mysql> delete from 表名;

5.权限管理

1. 登录和退出MySQL

远程登陆:

客户端语法:mysql -u 用户名 -p 密码 -h ip地址 -P端口号:如果没有改端口号就不用-P指

定端口

# mysql -hip地址 -P 3306 -uroot -p’密码’

# mysql -hip地址 -P 3306 -uroot -p’密码’ -e ‘show databases;’

-h 指定主机名 【默认为localhost】

-P MySQL服务器端口 【默认3306】

-u 指定用户名 【默认root】

-p 指定登录密码 【默认为空密码】

-e 接SQL语句,可以写多条拿;隔开

# mysql -hip地址 -P 3306 -uroot -p’密码’ -D mysql -e ‘show databases;’

此处 -D mysql为指定登录的数据库

2.创建表

mysql> create user tom@’localhost’ identified by ‘密码’; #创建用户为tom,并设置密码。

mysql> FLUSH PRIVILEGES; #更新授权表

注:

identified by :设置密码

在用户tom@’ ‘ 这里 选择:

%:允许远程登陆。也可以指定某个ip,允许某个ip登陆。也可以是一个网段。

%:包括所有的主机,不包括本机(127.0.0.1),但是不包括(localhost)

==客户端主机 % 所有主机

192.168.13.% 192.168.13.0网段的所有主机

192.168.13.252 指定主机 192.168.13.252

localhost 指定主机本机

3.使用命令授权:grant

也可创建新账户(不过后面的版本会移除这个功能,建议使用create user)

语法格式:

grant 权限列表 on 库名.表名 to ‘用户名’@’客户端主机’ IDENTIFIED BY ‘Qf@123’;

==权限列表 all 所有权限(不包括授权权限)

select,update

select, insert

==数据库.表名 *.* 所有库下的所有表 Global level

web.* web库下的所有表 Database level

web.stu_info web库下的stu_info表 Table level

给刚才创建的用户tom授权:

mysql> grant select,insert on *.* to ‘tom’@’localhost’;

mysql> FLUSH PRIVILEGES;

4.删除用户

方法一:DROP USER语句删除

DROP USER ‘用户名’@’localhost’;

方法二:DELETE语句删除

DELETE FROM mysql.user WHERE user=’tom’ AND host=’localhost’;

更新授权表: FLUSH PRIVILEGES;

你们的评论和点赞是我写文章的最大动力,蟹蟹。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/197169.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月5日 上,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SQL学习笔记三之MySQL表操作
https://www.cnblogs.com/JetpropelledSnake/p/9094125.html
Jetpropelledsnake21
2019/02/15
4020
MySQL常用语句
  今天天气很好,大晴天,心情也好好的。就将MySQL常用的语句总结一下,记录在随笔里,也顺便分享分享。日后,这篇随笔我将会持续更新,作为我自己的MySQL语句大全。
那一叶随风
2018/08/22
5600
MySQL常用sql语句
curd: 创建(Create)、更新(Update)、读取(Retrieve)和删除(Delete)
菜菜cc
2022/11/15
2.9K0
SQL常用语句
数据库是一个项目中最重要的核心,这里整理了一些常用的SQL语句,希望看完本篇文章后,你们能对使用SQL语句有一定的了解。
FGGIT
2024/10/15
1270
MySQL常见的库操作,表操作,数据操作集锦及一些注意事项
一 库操作(文件夹) 1 数据库命名规则 可以由字母、数字、下划线、@、#、$ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 2 数据库相关操作 创建库 create database 数据库名 ;    (注意要引号结尾)    (默认latin1) 在创建数据库的时候也可指定编码格式,如: create database 数据库名 charset utf8;  选择数据库 use 数据库名    切换到指定数据库下  查看库 show database
用户1214487
2018/01/24
1K0
Mysql常用sql语句(2)- 操作数据表
https://www.cnblogs.com/poloyy/category/1683347.html
小菠萝测试笔记
2020/06/09
5620
Mysql常用sql语句(2)- 操作数据表
MySQL基本操作
表是数据库存储数据的基本单位,由若干个字段组成,主要用来存储数据记录。表的操作 包括创建表、查看表、修改表和删除表。
星哥玩云
2022/08/18
2.1K0
MySQL基本操作
MySQL(五)之DDL(数据定义语言)与六大约束
前言 前面在数据库的讲解中,其实很多东西都非常的细节,在以前的学习过程中我都是没有注意到的。可能在以后的工作中会碰到所以都是做了记录的。 接下来,我将分享的是MySQL的DDL用来对数据库及表进行操作的。   mysql中保存了很多数据库、一个数据库中可以保存很多表。   对数据表的增(创建表)删(删除表)改(修改表字段)查(查询表结构)。  注意:这里的操作对象是表,对表的操作也就是表的结构,和表中的字段的操作(字段和记录要分清楚)   前提:表是在数据库下的,所以要先确实使用哪个数据库。 一、DDL之
用户1195962
2018/01/18
2.2K0
MySQL(五)之DDL(数据定义语言)与六大约束
MySQL 数据库基础知识(系统化一篇入门)[通俗易懂]
简单的说,数据库就是一个存放数据的仓库,这个仓库是按照一定的数据结构(数据结构是指数据的组织形式或数据之间的联系)来组织、存储的,我们可以通过数据库提供的多种方法来管理数据库里的数据。更简单的形象理解,数据库和我们生活中存放杂物的仓库性质一样,区别只是存放的东西不同。
全栈程序员站长
2022/09/13
5.4K0
MYSQL回顾(基础)
数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而且数据是按一定的格式存放的。 过去人们将数据存放在文件柜里,现在数据量庞大,已经不再适用。 数据库是长期存放在计算机内、有组织、可共享的数据即可。 数据库中的数据按一定的数据模型组织、描述和储存,具有较小的冗余度、较高的数据独立性和易扩展性,并可为各种 用户共享。
VV木公子
2020/02/18
6.3K0
【MySQL】:约束全解析
在为字段添加约束时,我们只需要在字段之后加上约束的关键字即可,需要关注其语法。我们执行上面的SQL把表结构创建完成,然后接下来,就可以通过一组数据进行测试,从而验证一下,约束是否可以生效。
屿小夏
2024/03/04
4560
【MySQL】:约束全解析
第三章《数据表的基本操作》
1.关于表 表示数据库存储数据的基本单位。一个表可以包含若干个字段或者是记录。表的操作包括创建表、修改表、删除表。创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性约束的过程。 1.创建表: 数据表属于数据库,在创建数据表之前,应该使用“USE <数据库名>”移动到指定的数据库下。 如果没有选择数据库,创建表时会报错; 创建表的语法: CREATE TABLE table_name ( 字段1 数据类型 [完整性约束条件], 字段2 数据类型 [完整性约束条件], … );
全栈程序员站长
2021/06/08
1.5K0
第三章《数据表的基本操作》
MySQL 常用语句(值得收藏)
Windows服务 -- 启动MySQL net start mysql -- 创建Windows服务 sc create mysql binPath= mysqld_bin_path(注意:等号与值之间有空格) 连接与断开服务器 mysql -h 地址 -P 端口 -u 用户名 -p 密码 SHOW PROCESSLIST -- 显示哪些线程正在运行 SHOW VARIABLES -- 显示系统变量信息 数据库操作 -- 查看当前数据库 SELECT DATABASE(); --
办公魔盒
2019/07/22
1.6K0
MySQL 常用语句(值得收藏)
常用sql语句
不是真正的修改数据库的编码格式 是设定当前数据库数据,显示的编码格式 不修改数据库原始的编码格式
summerking
2022/10/27
3880
mysql学习
MySQL相关操作 注意:在Windows系统中,关键词的大小写不会影响结果,但Linux系统需要区分大小写。 创建数据库 CREATE DATABASE 数据库名 charset utf8; 命名规则 可以由字⺟、数字、下划线 区分大小写 唯一性 不能使用关键字 不能单独使用数字 最长127位 数据库的相关操作 查看数据库 show databases; show create database db1; select database(); 选择数据库 use 数据库名;
Dreamy.TZK
2020/04/09
5580
mysql基础[运维专题]
简介:各个版本的区别 官网:https://dev.mysql.com/downloads/mysql/
高大北
2022/10/28
1.7K0
MySQL 常用的指令
mysql.server start 启动 mysql.server stop 关闭 quit 退出
陈雨尘
2019/05/23
1.4K0
02 . Mysql基础操作及增删改查
SQL(Structured Query Language 即结构化查询语言) SQL语言主要用于存取数据、查询数据、更新数据和管理关系数据库系统,SQL语言由IBM开发。
iginkgo18
2020/09/27
2K0
MySQL数据库、数据表的基本操作及查询数据
存储引擎比较 |功能|MyISAM|Memory|InnoDB|Archive| |---|---|---|---|---| |存储限制|256TB|RAM|64TB|None| |支持事务|No|No|Yes|No| |支持全文索引|Yes|No|No|No| |支持数索引|Yes|Yes|Yes|No| |支持哈希索引|No|Yes|No|No| |支持数据缓存|No|N/A|Yes|No| |支持外键|No|No|Yes|No|
星哥玩云
2022/08/17
3.4K0
入门MySQL——基础语句篇
前面几篇文章,我们介绍了MySQL的基础概念及逻辑架构。相信你现在应该有了自己的一套MySQL环境,接下来我们就可以开始练习MySQL了。本文将从MySQL最基础的语句出发,为你展示出创建及修改不同对象应该使用的标准语句。
MySQL技术
2019/09/08
4820
相关推荐
SQL学习笔记三之MySQL表操作
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档