关于MySql的一些基本操作

注册MySql服务
mysqld -install
启动MySql服务
net start mysql //启动MySQL服务
net stop mysql  //中止Mysql服务
退出MySQL终端
exit
quit
登录参数
mysql -u用户名 -p密码 -h要连接MySQL服务器的IP地址 —P端口号(默认3306)
卸载MySQL方法

1.net stop mysql

2.mysqld -remove mysql

3.删除MySQL目录和环境变量

SQL基础
  1. 每条语句以分号结尾
  2. SQL不区分大小写
  3. 单行注释为# 多行注释为/* 注释内容*/
约束

1.约束的概念

  • 约束作用于表中列上的规则,用于限制加入表的数据
  • 约束的存在保证了数据库中数据的正确性,有效性和完整性

2.约束的分类

约束名称描述关键字
非空约束保证列中数据不能为空NOT NULL
唯一约束保证列中所有数据各不相同UNIQUE
主键约束主键是一行数据的唯一标识,要求非空且唯一PRIMARY KEY
检查约束保证列中数据满足某一条件CHECK
默认约束保存数据时,未指定值时则采用默认值DEFAULT
外键约束外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性FOREIGN KEY

auto_increment 自动增长 列为数字类型且唯一约束才可以使用

添加外键(建表时) constraint 外键名字 foreign key(列名) references 表名(列名)

添加外键(建表后)alter table 表名 add constraint 外键名字 foreign key(列名) references 表名(列名)

删除外键 alter table 外键所在表 drop foreign key 外键名字;

DDL(数据定义语言)

操作数据库,表等

DDL操作数据库

查询全部数据库 show databases;
创建数据库 create database 数据库名 if not exists 数据库名; 
删除数据库 drop database 数据库名  if exists 数据库名;
使用数据库 use 数据库名;
查看当前数据库 select database(); 

DDL操作表

查看某个数据库的全部表 show tables; 必须先进入某个数据库
查看某个表的结构   desc 表名;
创建表 create table 表名 (字段名1 数据类型,字段名2 数据类型,字段名3 数据类型);
删除表 drop table 表名;
修改表名 alter table 表名 rename to 新表名;
添加一列 alter table 表名 add 列名  数据类型;
修改数据类型 alter table 表名 modify 列名 新数据类型;
修改列名和数据类型 alter table 表名 change 列名 新列名 新数据类型;
删除列 alter table 表名 drop 列名;

SQL数据类型

https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/data-types-transact-sql?redirectedfrom=MSDN&view=sql-server-ver16
DML(数据操作语言)

对数据进行增删改

添加数据 insert into 表名(列名1,……) values(值1,值2,……);给所有列添加数据可以省略列名 不建议省略
批量添加数据 insert into 表名(列名1,……) values(值1,值2,……),(值1,值2,……),(值1,值2,……);
修改数据 update 表名 set 列名1=值1,…… [where 条件]
删除数据 delete from 表名 [where 条件]
DQL(数据查询语言)

对数据进行查询

基础查询

查询某列数据 select 列名 from 表名;
查询去重后的数据 select distinct 列名 from 表名;
使用 as 起别名 select 列名 as 别名 from 表名;

条件查询

select 列名 from 表名 where 条件;
符号功能
>大于
<小于
>=大于等于
<=小于等于
=等于
<> !=不等于
between …… and ……在某个范围的集合
in()多选一
like模糊查询_单个任意字符 %多个任意字符
is null是NULL
is not null不是 NULL
and 或 &&并且
or 或 ||或者
not 或 !非,不是

排序查询

select 字段列表 from 表名 order by 排序字段名[排序方式1],排序方式名2[排序方式2];
ASC 升序排序(默认)
DESC 降序排序
如果有多个排序条件时,当前面条件一样时,才会根据第二条件排序

分组查询

聚合函数

函数名功能
count(列名)统计数量
max(列名)最大值
min(列名)最小值
sum(列名)求和
avg(列名)平均值

聚合函数语法:

select 聚合函数(列名) from 表;

分组查询语法

select 列名 from 表名 group by 分组字段名 where 限制条件(分组前使用) [having 限制条件(分组后)];
注意 :分组后,查询字段为分组字段和聚合函数 其他无意义
执行顺序 : where > 聚合函数 > having

分页查询

select 字段列表 from 表名  limit 起始索引,查询目录条数
起始索引 = (当前页码-1)* 每页显示的条数
limit为MySQL方言 Oracle使用rownumber SQLserver 使用top

多表查询

select 查询字段 from 表一,表二 where 条件;直接查询存在笛卡尔积的情况,会相互组合。
需要存在删除无效信息的情况
连接查询
	内连接(查询A表和B表的交集)
	select 查询字段 from 表一,表二 where 表一.ed_id = 表二.id;
	外连接
		左外连接(查询A表以及A表和B表的交集)
		右外连接(查询B表以及A表和B表的交集)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

How to Learn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值