mysql入门知识
数据库 什么是数据库
就是存储数据的仓库(容器) 存储数据的方式
1.变量 无法永久存储
2.文件处理 ,可以永久存储 文件处理存在的弊端:
1.文件处理速度慢
2.文件只能在自己的计算机上读写 无法被共享(局域网除外) 单台计算机的性能终归是有限的
1.升级你的硬件设备 提升幅度有限 垂直扩展
2.服务器集群 分布式 横向扩展 一旦把服务器拆分开后,数据就必须能够被不同计算机共享
必须通过网络,也就是socket 数据库软件的本质 也就是一个 基于socket(TCP)的C/S结构的程序 如果自己实现一个数据软件 需要解决的几个问题
1.一旦数据共享 就存在竞争问题,需要处理锁
2.不是所有的TCP连接请求都要接受,得加上安全验证
3.文件处理带来的效率问题, 需要想办法来提高处理速度 (索引) 有很多现成数据库软件可以直接使用,又分为两大类
1.关系型数据库
该类型的数据 提供某种机制 可以帮你维护 数据与数据之间的关系
例如 学员数据 和 班级数据 可以通过其中一方 找到另外一方
一般都是基于文件实现的
优点:容量大 可以永久存储
mysql 免费开源,开源支持中小型企业并发 oracle 商用收费,学习免费,功能比mysql强大,用户管理和集群
SQLServer 属于微软生态圈,只能运行于 windows上
mariaDB mysql创始人:韦德纽斯 担心 mysql的前程 于是基于mysql开发了mariaDB 用起来是一模一样
DB2 IBM 360
sqllite 非常轻量级的数据库 共同特征都支持SQL
结构化 查询语言
学习数据库的重点也就是SQL语句 2.非关系型数据库
数据与数据之间是独立 不存在任何关联关系
以key:value的形式来存储数据
一般基于内存
优点:速度快
问题:断电丢失 MongoDB
redis
memcache 该使用哪一类数据库?
应该搭配使用,把数据量大的 存到关系型中 把经常访问的放到非关系型中
提高访问速度 数据库相关的概念 数据 本质上一堆带有含义的符号
name = jack 数据记录
多个数据组成了一条完整记录
name,age,sex
jack,38,man
rose,20,woman 表 本质就是一个文件
里面存储一堆数据记录 库 本质就是一个文件夹
里面放一堆表文件 DBMS
data base manager system
数据库管理系统 (TCP的服务器)
负责管理一堆文件夹(即数据库) 数据库服务器
指的是运行有TCP服务器的程序 的计算机 DBMS和服务器 一般运维管
到公司之后会分给你一个账号密码 以及服务器地址 mysqld 是服务器主程序
mysqld 警告说:创建文件失败 由于权限不足 用管理员权限运行即可
mysql 是无界面的客户端 需要在CMD运行
mysql连接服务器 需要指定以下参数
-h 主机地址(ip)
-P 端口号
-u 用户名
-p 密码 服务器和客户端在同一台电脑 可以省略主机地址 端口号默认3306 可以省略
如果不指定用户名和密码 以游客模式登陆 什么都看不到 mysql 的安装:
1.带界面 一路next
2.压缩包 直接解压
2.1 添加环境变量
2.2 注册系统服务 修改管理员密码
1.如果知道原始密码 mysqladmin -uroot -p password 123
2.不知道原密码 可以在启动服务器时 跳过 授权表
mysqld --skip-grant-tables
无密码登录服务器 执行修改密码的指令
update mysql.user set password = password("新密码") where user = "root" and host = "localhost"; 关于库的 语句
创建库
create database 库名称
删除库
drop database 库名称
修改库的属性
alter database 库名称 charset = "新的编码"
查看创建库详细信息
show create database mydb;
查看所有数据库
show databases
选择一个数据库
use 库名称 关于表
增
create table 表名称(name char,age int);
create table 库.表名(name char,age int); 查看所有表
show tables;
查看表的详细信息
show create table t1;
查看表结构 (字段)
desc t1; 改
alter table t1 charset = "gbk"; 改编码
alter table t1 add sex char; 添加字段
alter table t1 drop sex; 删除字段
alter table t1 modify age char; 修改字段的类型
alter table t1 change age ages int; 修改字段的名字和类型
rename table t1 to table1; 修改表的名称 删除
drop table table1; 数据记录相关操作是重点学习对象
# 一次性插入多条记录
insert into table_name values("陈麻子",20);
# 一次性插入多条记录
insert into table_name values(值1,值2),(值2,值2),...;
上述语法 值的个数必须与字段的个数相同 # 指定要插入数据的字段
insert into t2(name) values("我只有姓名啊") 查看数据
select * from t2; * 表示查看所有字段 多个字段用逗号隔开 修改
update t2 set age = 100; 没有条件则全部修改
update t2 set age = 100 where name = "陈";
update t2 set age = 100,name = "刘铁柱" where name = "陈" ; 删除数据
delete from t2 where name = "刘铁柱";
mysql入门知识的更多相关文章
- MySql入门知识(一)
概述 MySQL是一个真正多用户,多线程结构化查询语言数据库服务器.MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司.MySQL的SQL语言是用于访问数据 ...
- java web mysql 入门知识讲解
MySQL学习笔记总结 一.SQL概述: SQL:Structured Query Language的缩写(结构化查询语言) SQL工业标准:由ANSI(ISO核心成员) 按照工业标准编写的SQ ...
- [置顶] Mysql存储过程入门知识
Mysql存储过程入门知识 #1,查看数据库所有的存储过程名 #--这个语句被用来移除一个存储程序.不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程 #SELECT NAME FROM ...
- 2. Mysql数据库的入门知识
2. Mysql数据库的入门知识 (1)打开Windows系统提供的服务查看相应的服务. (2)在Windows任务管理器的进程中查看 (3)使用命令行管理windows的Mysql数据库服务. Ne ...
- MySQL入门(三)
写了两篇<MySQL入门>以后我发现,写书的人还是都挺有本事的,起码人家知道怎么编排自己想讲的知识点,我实在是不知道该先说那里后说哪里,那我就想到什么讲什么吧. 一 写SQL 其实我是不想 ...
- zabbix入门知识
zabbix入门知识 zabbix中文手册 https://www.zabbix.com/documentation/3.4/manual/ 1.zabbix介绍 Zabbix 是一个企业级的分布式开 ...
- MySQL入门——MySQL数据库和SQL语言
MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...
- 《MySQL必知必会》学习笔记——附录A MySQL入门
附录A MySQL入门 如果你是MySQL的初学者,本附录是一些需要的基础知识. A.1 你需要什么 为使用MySQL和学习本书中各章的内容,你需要访问MySQL服务器和客户机应用(用来访问服务器的软 ...
- MySQL 基础知识梳理
MySQL 的安装方式有多种,但是对于不同场景,会有最适合该场景的 MySQL 安装方式,下面就介绍一下 MySQL 常见的安装方法,包括 rpm 安装,yum 安装,通用二进制安装以及源码编译安装, ...
随机推荐
- Python:基于MD5的文件监听程序
前述 写了一个基于MD5算法的文件监听程序,通过不同的文件能够生成不同的哈希函数,来实现实现判断文件夹中的文件的增加.修改.删除和过滤含有特定字符的文件名的文件. 需求说明 需要实现对一个文件夹下的文 ...
- SpringCloud学习系列之五-----配置中心(Config)和消息总线(Bus)完美使用版
前言 在上篇中介绍了SpringCloud Config的使用,本篇则介绍基于SpringCloud(基于SpringBoot2.x,.SpringCloud Finchley版)中的分布式配置中心( ...
- 【Java】几道常见的秋招面试题
前言 只有光头才能变强 Redis目前还在看,今天来分享一下我在秋招看过(遇到)的一些面试题(相对比较常见的) 0.final关键字 简要说一下final关键字,final可以用来修饰什么? 这题我是 ...
- C#删除字符串最后一个字符
例:字符串 string str="2,3,5,7,9," 去掉最后一个逗号 ","; 常用的方法: 1.SubString()方法 str=str.SubSt ...
- Android之OkHttp详解
文章大纲 一.OkHttp简介二.OkHttp简单使用三.OkHttp封装四.项目源码下载 一.OkHttp简介 1. 什么是OkHttp 一般在Java平台上,我们会使用Apache Htt ...
- git相关的操作
给大家分享下git的使用心得,有不足的请大家补充: 克隆:git clone https://XXXXX 克隆指定分支:git clone -b https://XXXX 添加所有:git add . ...
- 20171201 - macOS High Sierra 神级 bug
昨日亲测有效,macOS High Sierra 神级 bug,系统管理员 root 密码为空,输入就可以登录,具备最高权限. 让人不禁想象 Apple Software 怎么了,人才都流失了吗?
- 基于Kubernetes 构建.NET Core 的技术体系
很多公司技术支持岗位的工作,如配置域名,部署环境,修改复位配置,服务重启,扩容缩容,梳理和完善监控,根据开发的需要查找日志等工作,需要和开发进行大量的沟通,如什么是外网域名,什么是内网域名.A nam ...
- 【jframe】Java架构师之路 - 第01篇:Get Started
jframe是什么? jframe是一个基于MIT协议开源的java web应用程序框架,汇聚了我们团队之于java web应用程序的核心架构思想以及大量最佳实践,并且持续在实际项目中不断完善优化. ...
- ReactiveSwift源码解析(四) Signal中的静态属性静态方法以及面向协议扩展
上篇博客我们聊了Signal的几种状态.Signal与Observer的关联方式以及Signal是如何向关联的Observer发送事件的.本篇博客继续上篇博客的内容,来聊一下Signal类中静态的ne ...