zoukankan      html  css  js  c++  java
  • 数据库初识及操作命令

    数据库初识

    DBMS(数据库管理系统)

    ​ 数据库管理系统是为管理数据库而设计的电脑软件系统, 一般具有存储, 截取, 安全保障, 备份等基础功能

    ​ 通俗来说, 这个工具负责通过操作系统和硬盘交流, 高效的管理数据, 并且还支持对外通信, 相当于一个socket服务端, 想操作数据的人或项目都可以连接到这个工具, 并通过这个工具来管理数据

    关系型数据库(RDBMS)

    ​ 关系型数据库模型是把负责的数据结构归结为简单的二元关系

    ​ 这几个表之间建立了某种关系, 共享着双方的数据. 这就是关系. 关系型数据库存储的数据大概就是这个样子

    结构化查询语言(SQL)

    ​ 操作关系型数据库的命令, 称之为SQL

    ​ SQL是一种特殊目的的编程语言, 是一种数据库查询和程序设计语言, 用于存取数据以及查询, 更新和管理关系数据库系统; 同时也是数据库脚本文件的扩展名.

    ​ 不同数据库系统之间的SQL不能完全相互通用

    常用的关系型数据库:

    oracle数据库

    ​ Oracle前身叫SDL、由Larry Ellison和两个变成任意在1977创办,他们开发了主机的拳头产品,在市场上大量销售。Oracle公司是最早开发关系型数据库的厂商之一,其产品支持最广泛的操作系统平台。目前Oracle关系数据库产品的市场占有率数一数二 。
      Oracle公司是目前全球最大的数据库软件公司,也是近年业务增长极为迅速的软件提供与服务商
      主要应用范围:传统大企业、大公司、政府、金融、证券等。
      版本升级:oracle8i,oracle9i,oracle10g,oracle11g,oracle12c

    MySQL

      MySQL被广泛的应用在Internet上的大中小型网站中。由于体积小、速度快、总体拥有成本低,开放源代码

    MariaDB数据库

    ​ MAriaDB数据库管理系统是MySQL数据库的一个分支,主要由开元社区维护,采用GPL授权许可。开发这个MariaDB的原因之一是:甲骨文公司收购了MySQL后,有MySQL闭源的潜在风险,因此MySQL开元社区采用分支的方式来避开这个风险。

    ​ MariaDB基于事务的Maria存储引擎,替换了MySQL的MyISAM的存储引擎,它使用了Percona的XtraDB(InnoDB的变体)这个版本还包括了PrimeBase XT (PBXT)和Federated X存储引擎。

    SQL Server数据库

    ​ Microsoft SQL Server是微软公司开发的大型关系数据库系统。SQL Server的功能比较全面,效率高,可以作为中型企业或单位的数据库平台。SQL Server可以与Winodws操作系统紧密集成,不论是应用程序开发速度还是系统事务处理运行速度,都得到较大的提升,对于在Windows平台上开发的各种企业级信息管理系统来说,不论是C/S(客户机/服务器)架构还是B/S(浏览器/服务器)架构。SQL Server都是一个很好的选择。SQL Server的缺点是只能在Windows系统下运行

    Access数据库

    ​ Access是入门级小型桌面数据库,性能安全性都很一般,可供个人管理或小型企业只用
      Access不是数据库语言,只是一个数据库程序,目前最新版本为Office 2007,其特点主要如下:
      (1)完善地管理各种数据库对象,具有强大的数据组织,用户管理、安全检查等功能
      (2)强大的数据处理功能,在一个工作组级别的网络环境中,使用Access开发的多用户管理系统具有传统的XSASE(DBASE、FoxBASE的统称)数据库系统所无法实现的客户服务器(Ckient/Server)结构和响应的数据库安全机制,Access具备了许多先进的大型数据管理管理系统所具备的特征。
      (3)可以方便地生成各种数据对象,利用存储的数据建立窗体和报表
      (4)作为Office套件的一部分,可以与Office集成,实现无缝连接
      (5)能够利用Web检索和发布数据,实现与Internet的连接,Access主要适用于中小企业应用系统,或作为客户机/服务器系统中的客户端数据库。

    其他不常用关系型数据库

    ​ DB2,PostgreSQL,Informix,Sybase等。这些关系型数据库逐步的淡化了普通运维的实现,特别是互联网公司几乎见不到

    非关系型数据库

    ​ 非关系型数据库也被称为NoSQL数据库, NoSQL的本意是"NOT ONLY SQL", NoSQL数据库在特定的场景下可以发挥出难以想象的高效率和高性能.传统的关系型数据库对于规模日益扩大的海量数据, 超大规模和高并发的微博, 微信等动态网站已经显得力不从心

    ​ 非关系型数据库(NoSQL)类的数据就是这样诞生并迅速发展, 高性能, 高并发, 对数据一致性要求不高

    ​ 开源的NoSQL体系,如Facebook的Cassandra,Apache的HBase,也得到了广泛认同,Redis,mongb也逐渐越来越受到各类大中小型公司的欢迎和追捧

    小结

    ​ 1, NOSQL不是否定关系数据库,而是作为关系数据库的一个重要补充 2, NOSQL为了高性能、高并发而生,忽略影响高性能,高并发的功能
      3, NOSQL典型产品memcached (纯内存),redis(持久化缓存),mongodb(文档的数据库)

    MySQL

    安装目录

                ![](https://img2018.cnblogs.com/blog/1730033/201911/1730033-20191126165117311-1672307125.png)
    
                ![](https://img2018.cnblogs.com/blog/1730033/201911/1730033-20191126165205009-1420264694.png)
    

    配置my.ini(默认参数)

    [client]
    #设置mysql客户端默认字符集
    default-character-set=utf8 
    
    [mysql]
    #设置mysql客户端默认字符集
    default-character-set=utf8 
    user = 'root'
    password = '123'
    
    [mysqld]
    #设置3306端口
    port = 3306 
    # 设置mysql的安装目录
    basedir=E:mysql-5.6.45-winx64 
    # 设置mysql数据库的数据的存放目录
    datadir=E:mysql-5.6.45-winx64data 
    # 允许最大连接数
    max_connections=200
    # 服务端使用的字符集默认为8比特编码的latin1字符集
    character-set-server=utf8
    # 创建新表时将使用的默认存储引擎
    default-storage-engine=INNODB
    

    root用户修改密码

    方法一:

    ​ 使用 set password 命令

    ​ 首先登陆MySQL, 使用mysql自带的那个客户端连接上mysql

    ​ 格式: mysql > set password for 用户名@localhost = password('新密码')

    方法二:

    ​ 使用mysqladmin(因为我们将bin已经添加到环境变量了, 这个mysqladmin也在bin目录下, 所以可以直接使用这个mysqladmin功能, 使用它来修改密码)

    ​ mysqladmin, 是一个执行管理操作的客户端程序. 可以用来检查服务器的配置和当前状态, 创建和删除数据库, 修改用户密码等等的功能, 虽然mysqladmin的很多功能通过MySQL自带的mysql客户端可以搞定, 但是有时候使用mysqladmin操作会比较简单

    ​ 格式: mysqladmin -u用户名 -p旧密码 password 新密码

    ​ 但是这种方式会直接明文显示密码, 所以最好连接进入到mysql里面之后, 在进行密码的修改和设置

    方法三:

    ​ 用update直接编辑mysql库中的user表

    ​ 首先登录MySQL, 连接上mysql服务端

    mysql>use mysql;
    # use mysql 的意思是切换到mysql这个库, 这个库是所有的用户表和权限相关的表都在这个库里面, 我们进入到这个库才能修改这个库里面的表
    mysql>update user set password=password('123') where user='root' and host='localhost';
    # 其中 password=password('123')前面的password是变量, 后面的password 是mysql提供的给密码加密用的, 我们最好不要明文的存密码, 其中user是一个表, 存着所有的mysql用户的信息
    mysql>flush privileges;
    # 刷新权限, 让其生效, 否则不生效, 修改不成功.
    

    root用户忘记密码

    ​ 关闭正在运行的MySQL服务, net stop mysql(这个mysql是你添加的mysqld到系统服务时的服务名)

    ​ 打开DOS窗口, 转到mysqlin目录.

    ​ 输入mysqld --skip-grant-tables 回车. --skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证, 因为之所以mysql启动之后, 客户端连接的时候需要登录认证, 输入密码, 因为mysql服务端启动的时候, 加载了自己内部的一些权限相关信息的授权表, 权限认证表什么的, 这样就要求客户端必须有认证, 如果启动的时候没有加载这些表和设置, 那么我们客户端再进行登录的时候, 就不需要认证了, 登录之后登录之后到mysql这个存有所有用户信息的表中去修改密码.(但是有个问题, 这个过程中需要关闭服务端, 以后解决).

    ​ tips:

    ​ 有一个问题, 直接使用上述指令, 直接通过mysqld启动服务的话, 就不能通过net stop mysql的方式来关闭服务了, 所以用到杀死进程这个指令(win10): tasklist|findstr mysqld 找到mysqld服务的端口号, 然后taskkill/F/PID 端口号来杀死这个mysql服务的进行, 以后就可以使用net start/net stop mysql的方式来启动和关闭了

    ​ 再开一个DOS窗口, 转到mysqlin目录

    ​ 输入mysql回车, 如果成功, 将出现MySQL提示符 >

    ​ 连接权限数据库: use mysql

    ​ 改密码: update user set password=password("123") where user="root";

    ​ 刷新权限(必须步骤): flush privileges; 凡是涉及到密码修改或者后面我们会学到的权限修改, 修改完之后全部要执行这一句

    ​ 退出 quit

    ​ 注销系统, 再进入, 使用新密码登录修改编码

    永久修改编码

    ​ 在数据库软件中的my.ini中 可以配置默认编码集,这样以后再创建时默认的就是配置中的编码集

    简易SQL语句

    数据库的操作

    增:

    ​ create database 数据库名 charset utf8

    ​ 创建一个库, 可以指定字符集

    删:

    ​ drop database 数据库名

    ​ 删除某个库

    改:

    ​ alter database 库名 charset utf8

    ​ 修改库的字符集

    查:

    ​ show databases

    ​ 查看数据库中所有的库

    ​ show create database 库名

    ​ 查看单独某个库的创建信息

    表的操作
    表的介绍

    ​ 表相当于文件, 表中的一条记录就相当于文件中的一行内容, 表中的一条记录有对应的标题, 称为表的字段

    操作前先切换:

    ​ use 库名

    ​ 要操作表文件, 先切换到对应的库下 , 才能操作表

    增:

    ​ create table t1(id int, name char(10))

    ​ 创建一个表, 设置字段以及记录格式

    删:

    ​ drop table t1

    改:

    ​ alter table t1 modify name char(3)

    ​ 修改字段属性, 将name字段的char长度改为3

    ​ alter table t1 change 旧字段名 新字段名 新数据类型

    查:

    ​ select database()

    ​ 查看当前所在的是哪个库

    ​ show tables

    ​ 查看当前库中所有的表

    ​ show create table t1

    ​ 查看表的创建信息

    ​ desc t1

    ​ describe t1

    ​ 这两个是一样的结果, 查看表信息

  • 相关阅读:
    2016huasacm暑假集训训练四 递推_A
    2016huasacm暑假集训训练三 G
    2016huasacm暑假集训训练三 F
    今年暑假不AC
    Who's in the Middle
    The Suspects
    食物链
    抓牛问题
    士兵队列训练问题
    H
  • 原文地址:https://www.cnblogs.com/beichen123/p/11936767.html
Copyright © 2011-2022 走看看