学习笔记—MySQL基础
数据库的介绍
mysql数据库介绍
开放源码的轻量级关系型数据库管理系统,体积小、速度快、操作便捷。
数据库的启动和连接
mysql数据库启动
在终端输入以下命令,启动mysql服务器
service mysql start
输入命令,查询mysql服务器状态
service mysql status
出现如下提示表示mysql服务器以启动成功
mysql数据库连接
输入账户和密码连接数据库
表示启动成功。
mysql数据库断开连接
输入exit,如果显示Bye表示断开成功。
数据库的操作
显示数据库
show databases;
创建数据库
create database 库名 default character set utf8;
删除数据库
drop database 库名;
使用数据库
use 库名;
表示以成功切换到study数据库。
数据表的操作
显示数据表
show tables;
创建数据表
## 创建表语句
create tables 表名(字段名 类型 约束,字段名 类型 约束,......);
## 注意:mysql是没有序列的,但是可以在创建表的时候直接指定主键是自赠的。
在字段后使用 auto_increment 表示自增。 ## MySQL常见字段类型
数值类型:
int(长度)表示整数类型的数据
float/double表示浮点数
字符类型:
varchar(长度)动态分配存储长度
char(长度)分配固定长度
日期类型:
date:格式为yyyy-mm-dd
datetime:格式为yyyy-MM-dd hh:mm:ss 占用8个字节
timestamp:特点:会自动进行时区的转换,占用4个字节
time:时间
year:年份
其他类型:
TEXT:字符数据
BLOB:二进制数据 ## 约束
主键约束:
在创建表时,在字段后使用 primary key 即可
在创建表语句的最后面使用 constraint 约束名 pirmary key(主键字段名)
非空约束:
在创建表的时候直接在字段后使用 nut null 即可
注意:
mysql的非空约束中空字符是可以存储进去的。
检查约束:
在mysql中是没有检查约束的,但是使用check关键字又不会报错。
解决:
使用代码逻辑进行无效的数据过滤。
使用 mysql 的存储过程。
唯一约束:
在字段名后直接使用 unique 即可
在创建表语句的最后面使用 constraint 约束名 unique(字段名)
外键约束:
在字段名后直接使用 references 父表名(父表主键名)
在创建表语句的最后面使用 constraint 外键约束名 foreign key(字段名) references 父表名(父表主键名) ## 在表外部添加约束
## 主键约束
alter table 表名 add constraint 约束名 pirmary key(主键字段名);
## 唯一约束
alter table 表名 add constraint 约束名 unique key(字段名);
## 非空约束
alter table 表名 modify 字段名 类型 not null;
## 外键约束
alter table 表名 constraint 外键约束名 foreign key(字段名) references 父表名(父表主键名)on delete set null on update cascase;
修改数据表
添加字段:
alter table 表名 add 字段名 类型 约束;
删除字段:
alter table 表名 drop 字段名;
修改字段类型:
alter table 表名 modify 字段名 新的类型;
修改字段名:
alter table 表名 change 字段名 新的字段名 类型;
修改表名:
alter table 表名 rename as 新的表名;
删除数据表
drop table 表名;
查看表创建语句
show create table 表名;
表数据的操作
查询数据
## 单表查询
## 查询全部
select * from 表名;
## 别名
直接在字段后使用即可
select 字段,字段 别名,字段 from 表名;
## 连接符
使用concat(字段名,“连接的字符”)
## 去除重复
使用 distinct 关键字即可
## 排序
order by 字段名
## where字句
select * from 表名 where 判断条件;
## 分组
group by 字段名
注意:
分组可以和字段一起使用
## having
分组后筛选
## 多表查询
select * from 表名1 别名1,表名2 别名2 where 别名1.字段名 判断条件 别名2.字段名; select * from 表名1 别名1 inner join 表名2 字段名2 on 别名1.字段名 判断条件 别名2.字段名;
## 子查询
select * from 表名 where 字段名 in (select 字段名 from 表名 where 查询条件);
增加数据
insert into 表名 values(值1,值2,值3,...); 全字段插入
insert into 表名(主键字段名,字段,字段,...) values(值1,值2,值3,...); 部分字段插入
删除数据
delete from 表名 where 条件;
修改数据
update 表名 set 字段名=值,字段名=值,... where 条件;
分页查询
select * from 表名 limit x,y;
x:从第几条数据开始查询
y:每页显示多少条数据 ## 每页显示n条,查询第m页的信息
select * from 表名 limit m*n-n,n;
数据库的备份
导出
## 导出整个数据库
mysqldump -u root -p 数据库名>/目录/文件名.sql;
## 只导出一个表
mysqldump -u root -p 数据库名 表名>/目录/文件名.sql;
导入
## 方法一 连接数据库之后输入
mysql>source /目录/文件名.sql;
## 方法二 连接数据库之前输入
mysql -u root -p 数据库名<文件名.sql;
学习笔记—MySQL基础的更多相关文章
- 数据库学习笔记 - MySQL基础知识
一.数据库基础知识 1.1 Whats's 数据库 数据库(Database,DB):将大量数据保存起来,通过计算机加工而成的可以进行高效访问的数据集合.如:大型-银行存储的信息,小型-电话簿. 数据 ...
- MyBatis:学习笔记(1)——基础知识
MyBatis:学习笔记(1)--基础知识 引入MyBatis JDBC编程的问题及解决设想 ☐ 数据库连接使用时创建,不使用时就释放,频繁开启和关闭,造成数据库资源浪费,影响数据库性能. ☐ 使用数 ...
- mybatis学习笔记之基础框架(2)
mybatis学习笔记之基础框架(2) mybatis是一个持久层的框架,是apache下的顶级项目. mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成满足s ...
- bootstrap学习笔记之基础导航条 http://www.imooc.com/code/3111
基础导航条 在Bootstrap框中,导航条和导航从外观上差别不是太多,但在实际使用中导航条要比导航复杂得多.我们先来看导航条中最基础的一个--基础导航条. 使用方法: 在制作一个基础导航条时,主要分 ...
- Django学习笔记(基础篇)
Django学习笔记(基础篇):http://www.cnblogs.com/wupeiqi/articles/5237704.html
- MySQL学习笔记-MySQL体系结构总览
MySQL体系结构总览 不管是用哪种数据库,了解数据库的体系结构都是极为重要的.MySQL体系结构主要由数据库和数据库实例构成. 数据库:物理操作系统文件或者其它文件的集合,在mysql中,数据库文件 ...
- C#学习笔记(基础知识回顾)之值类型与引用类型转换(装箱和拆箱)
一:值类型和引用类型的含义参考前一篇文章 C#学习笔记(基础知识回顾)之值类型和引用类型 1.1,C#数据类型分为在栈上分配内存的值类型和在托管堆上分配内存的引用类型.如果int只不过是栈上的一个4字 ...
- C#学习笔记(基础知识回顾)之值传递和引用传递
一:要了解值传递和引用传递,先要知道这两种类型含义,可以参考上一篇 C#学习笔记(基础知识回顾)之值类型和引用类型 二:给方法传递参数分为值传递和引用传递. 2.1在变量通过引用传递给方法时,被调用的 ...
- C#学习笔记(基础知识回顾)之值类型和引用类型
一:C#把数据类型分为值类型和引用类型 1.1:从概念上来看,其区别是值类型直接存储值,而引用类型存储对值的引用. 1.2:这两种类型在内存的不同地方,值类型存储在堆栈中,而引用类型存储在托管对上.存 ...
随机推荐
- 一份完整的阿里云 Redis 开发规范,值得收藏!
来源:yq.aliyun.com/articles/531067 作者:付磊-起扬 本文主要介绍在使用阿里云Redis的开发规范,从下面几个方面进行说明. 键值设计 命令使用 客户端使用 相关工具 通 ...
- [翻译 EF Core in Action 1.9] 掀开EF Core的引擎盖看看EF Core内部是如何工作的
Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...
- Element表格嵌入复选框以及单选框
1,element 表格嵌入CheckBox 效果图如下: 2,element结合checkBox实现单选效果如下: html代码: <template> <div> < ...
- Github项目推荐-图神经网络(GNN)相关资源大列表
文章发布于公号[数智物语] (ID:decision_engine),关注公号不错过每一篇干货. 转自 | AI研习社 作者|Zonghan Wu 这是一个与图神经网络相关的资源集合.相关资源浏览下方 ...
- 使用OSG创建一个简单的地形
目录 1.解决方案 1) 使用TIF格式的DEM 2) 描述HeightField 2.存在问题 3.参考文档 1.解决方案 在网上参考了一些资料,使用OSG创建地形最简单的办法就是使用OSG::He ...
- Altium Designer快速调整丝印
Altium Designer快速调整丝印 今天我为大家讲的内容是altium designer快速调整丝印,这是我们做完PCB设计布线完成后的下一个步,很多朋友都是非常熟悉的.但是我们很多人只会用a ...
- 将博客搬至CSDN https://blog.csdn.net/Fredric_2014
将博客搬至CSDN https://blog.csdn.net/Fredric_2014
- 宝塔面板设置腾迅COS自动备份网站
之前写了如何配置腾迅云COS并挂载到服务器中,今天看到宝塔面板中有腾迅云COS的插件,不过研究了下,只是将COS绑定在宝塔面板中,不能自动备份,需要用到宝塔的计划任务功能 1.下载腾迅云COS插件 2 ...
- 模式识别笔记3-支持向量机SVM
1. 线性SVM 对两类点的划分问题,这里对比下逻辑回归和SVM的区别: 逻辑回归的思想是,将所有点到决策平面的距离作为损失来进行训练,目标是到决策平面的距离和最小 SVM的思想是,只关注支持向量(图 ...
- 【Python实践-2】求一个或多个数的乘积
# -*- coding: utf-8 -*- #定义一个函数,可接收一个或多个数并计算乘积 def product(*numbers): s=1 for n in numbers: s=s*n re ...