MySQL基础入门使用和命令的使用
数据库了解
- 概念
- 数据库就是一种特殊的文件,其中存储着需要的数据
- 一个数据库可以有多张表
- MySQL是一种关系型数据库
- 具有关联性数据的就是关系型数据库
- MySQL是一种软件可以用来创建mysql数据库
- MySQL也是C/S构架(底层TCP)
- MySQL客户端
- 客户端连接服务端使用TCP协议连接
- 使用时SQL语句操作
- MySQL服务器
- MySQL服务器操作数据库
- MySQL客户端
- 数据库优点
- 持久化存储
- 读写速度高
- 保存速度有有效性
- 对程序支持非常好,容易扩展
- 数据库词汇
- 列:字段
- 行:记录
- 表:记录的集合
- 主键:唯一标记一行记录的
- 外键:对于一张表中某个字段的值是另一张表的主键的值
- 常见的关系型数据库及底层了解
- RDBMS
- 是一种程序的简称,分为关系型数据库和非关系型数据库
- 关系型数据库
- MySQL(常用与制作网站)
- 常用版本:5.1 5.6 5.7 5.8
- sqlite
- Oracle
- 常用版本 Oracle 10g Oracle 11g
- sqlserver(Microsoft)
- db2(IBM)
- MySQL(常用与制作网站)
- 非关系型数据库
- redis(处理缓存)
- mangodb(存储非关系型数据)
- RDBMS
SQL语言概念
- SQL语句是一种结构化查询语句,可以用来操作RDBMS数据库语言
- sql语句分类
- DQL查询
- select
- DML操作
- insert update delete
- DQL查询
MySQL基础操作
- 安装
- ubuntu:
- sudo apt-get install mysql-server(服务端)
- sudo apt-get install mysql-client(客户端)
- ubuntu:
- 启动
- sudo service mysql start
- 暂停
- sudo service mysql stop
- 重启
- sudo service mysql restart
- 配置文件
- /etc/mysql/mysql.conf.d/mysqld.cnf
MySQL的主要数据类型和约束
数据类型
整数型
- int
- bit
小数
- decimal
- decimal(5, 2),表示一共存5位数,小数占2位
- decimal
字符串
- varchar
- char
- char(3)表示固定长度的字符串,长度不够会用空格补全,不可以超过3个字符
- varchar
- varchar(3)填充ab就会存储ab,不可以超过3个字符
时间类型
- data, time, datatime
枚举类型
- enum
- 比如性别,代表只有固定的类型让人选择
- enum
test类型
- 当字符大于4000之后推荐使用
ps:
- 对于图片,音频,视频等文件,不存储在数据库中,而是上传到服务器中,数据库只保存文件的保存路径
约束
约束是用来限制每一个字段的
主键primary key
- 物理上存储的顺序
非空not null
- 此字段不允许为空
外键
数值类型
- tinyint 1个字节,0-255
- smallint 2个字节 0-65535
- mediumint 3个字节
- int/integer 4个字节
- bigint 8个字节
字符串
- char
- barchar
- text
用命令来操作数据库
数据库连接
- mysql -uroot -pmysql
- mysql -uroot -p (这种方式需要写密码)
退出数据库
- quit/exit/ctrl+d
查看数据库
- show databases;
显示时间
- select now();
显示版本
- select version();
创建数据库
- create database python;(创建一个名称为Python的数据库)
- create database pythonnew charset=utf8;(创建一个字符集为utf8编码名称为pythonnew的数据库)
删除数据库
- drop database python;(删除名称为Python的数据库)
使用数据库
- use 数据库名称
查看当前使用数据库
- select database();
数据表操作
- 显示数据库所有的表
- show tables;
- 创建一个数据表
- create table xxxxx(id int, name varcharm(30)); # 一个逗号创建一个字段
- create table xxxxx(id int primary key not null auto_increment, name varcharm(30)); # 添加约束在每一个字段后面加上约束
- 案例创建一个students表(id,name,age,high,gender,cls_id)
create table students(
id int unsigned not null auto_increment parimary key,
name varchar(30),
age tinyint unsigned defult 0,
high decimal(5,2),
gender enum("男","女") default "男",
cls_id int unsigned
ps:
- 创建表顺序(字段名 类型 约束)
desc 数据表的名字;(可以快速查看表结构)
数据表字段结构的的增删减查
- 增
- alter table students add birthday datetime;
- alter table 表名
- 删
- drop table 表名
- 改
- alter table 表名 modify brithday data; 不重名
- alter table 表名 change brithday birth date default '1990-01-01'; 重名
- 查
ps:
show create table students; # 可以查看创建这个数据表的SQL语句
数据的增删改查
- 增:
- insert into 表名 values(....)
- insert into 表名 values(....),(....)
- insert into 表名(字段,字段) values (值1, 值2)
- insert into 表名(字段,字段) values (值1, 值2),(值1,值2)
- ps:
- 枚举中数字1代表
- 改:
- update 表名 set 字段=值 (直接修改全部字段)
- update 表名 set 字段=值 where name=值 (在满足where后面的条件,一般用主键来判断来指定修改)
- update 表名 set 字段=值,字段2=值 where name=值 (一次修改多个值)
- 查询
- select 指定字段 from 表名 (*代表所有的字段)
- select 指定字段 as 命名 from 表名 (可以修改字段的名称显示出来)
- 删
- truncate students;(清空表)
- delete from 表名; (删除表的所有内容)
- delete from 表名 where id<6; (指定删除)
- 不要去删除数据,可以添加字段来逻辑删除
- alter table students add is_delete bit default 0;
- update students set is_delete=1 where id=6;
MySQL基础入门使用和命令的使用的更多相关文章
- MySQL基础入门之常用命令使用
如何启动MySql服务 /etc/init.d/mysqld start service mysqld start Centos .x 系统 sysctl start mysqld 检测端口是否运行 ...
- MySQL基础入门之常用命令介绍
mysql命令介绍 mysql 是数据库管理命令 通过mysql --help来查看相关参数及使用说明 mysql --help #mysql数据库管理命令 Usage: ...
- 【转载】20分钟MySQL基础入门
原文:20分钟MySQL基础入门 这里持续更新修正 开始使用 MySQL 为关系型数据库(Relational Database Management System),一个关系型数据库由一个或数个表格 ...
- mysql 基础入门 单表查询
单表查询 select 表头,表头 as 别名 ,表头(+-*/的运算) from table_a 1.条件查询 where + 条件 <> , != 不等于 = 等于,也可以表示字符串值 ...
- 1、mysql基础入门(1)
1.mysql基础入门: 1.1.数据库介绍:
- MySQL基础入门(1)
MySQL基础入门(1) 为什么学习MySQL 关系数据库管理系统(Relational Database Management System, RDBMS)是一种极为重要的工具,其应用十分广泛,从商 ...
- MySQL快速入门及常用命令
数据库 笔记内容 SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,F ...
- MySQL基础知识和常用命令总结
说明:以下内容是阅读书籍<<MySQL必知必会>>的摘要和总结 检索数据 排序检索数据 过滤数据 使用通配符过滤 使用正则表达式进行搜索 创建计算字段 使用数据处理函数 汇总数 ...
- MySQL 基础入门
MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用 ...
随机推荐
- 用什么库写 Python 命令行程序?看这一篇就够了
作者:HelloGitHub-Prodesire HelloGitHub 的<讲解开源项目>系列,项目地址:https://github.com/HelloGitHub-Team/Arti ...
- 办公环境下k8s网络互通方案
在 kubernetes 的网络模型中,基于官方默认的 CNI 网络插件 Flannel,这种 Overlay Network(覆盖网络)可以轻松的实现 pod 间网络的互通.当我们把基于 sprin ...
- CSS颜色表示的几种方式
在CSS中颜色有很多表示方式,今天列出一些常见的颜色表示方式及它们的用法. ①color:blue; 第一种,调用颜色属性,将颜色的英文输入在冒号后,以分号结束. 这种方法直接了当,但是能表示的颜色 ...
- java13人机猜拳
public class Demo01 { public static void main(String[] args) { /* * 你同桌和你要玩游戏. * 1 剪刀,2 石头,3 布 */ // ...
- 基于 HTML5 WebGL 的智慧楼宇可视化系统
前言 可视化的智慧楼宇在 21 世纪是有急迫需求的,中国被世界称为"基建狂魔",全球高层建筑数量位居首位,所以对于楼宇的监控是必不可少.智慧楼宇可视化系统更多突出的是管理方面的功能 ...
- JCL、SLF4J、Log4J、Log4J2、LogBack和JUL之间的关系,你搞清楚了吗?
写在前面 日志组件是我们平时开发过程中必然会用到的组件.在系统中正确的打印日志至少有下面的这些好处: 调试:在程序的开发过程中,必然需要我们不断的调试以达到程序能正确执行的状态 .记录日志可以让开发人 ...
- Python原来这么好学-1.1节: 在windows中安装Python
这是一本教同学们彻底学通Python的高质量学习教程,认真地学习每一章节的内容,每天只需学好一节,帮助你成为一名卓越的Python程序员: 本教程面向的是零编程基础的同学,非科班人士,以及有一定编程水 ...
- 基于LNMP架构部署NextCloud私有云盘
一.NextCloud 概述 云盘这个词无论是做技术出身的朋友还是普通的网民.想必已经听的非常多了.在日常生活当中我们用的最多的云盘莫过于百度网盘了 在前几年百花齐放的网盘市场.到现如今只剩下了百度网 ...
- Nice to meet you for the first time .Why do I write blog!
他们说我不修边幅,因为他们没看到我对细节的追求,他们说我技术宅,因为他们看不懂我的悲欢,他们说我无趣,是因为她们不知道,我在让世界变得更有趣,我把误解拿来自黑,我用工作承载兴趣,我是程序员,是用代码编 ...
- 5.7.20 多实例——MGR部署实战
数据库 | MySQL:5.7.20 多实例——MGR部署实战 MGR介绍 基于传统异步复制和半同步复制的缺陷——数据的一致性问题无法保证,MySQL官方在5.7.17版本正式推出组复制(MySQL ...