1.mysql启动的实质:

在单实例中,/etc/init.d/mysql start 是一个shell脚本,调用mysqld_safe脚本,最后调用mysqld服务启动mysql。

2. 关闭mysql有两种方式,mysqladmin  -uroot -poldboy124 shutdown 或者    /etc/init.d/mysql  stop

3.  对于mysql要多用:help,就像是linux 中的man,help一样。

4.修改密码两种方式:

1)mysqladmin   -uroot -poldboy124  password '123'---必须有原密码

2)update mysql.user  set  password=password(456)  where user='root'  and host='localhost'

5.密码丢失:

1)/etc/init.d/mysql stop

2)  mysqld_safe --skip-grant-tables --user=mysql & (跳过授权页面进行mysql服务开启,即登陆不需要密码)

3)mysql进行登陆

4)pdate mysql.user  set  password=password(456)  where user='root'  and host='localhost'

5)lush  privileges

6)quit

7)  mysqladmin -uroot -p124 shutdown

8)正常方式重新登陆

6.什么是sql?

sql就是结构化查询语言,对关系型数据库中的数据进行定义和操作的语言方法,是大多数关系数据库管理的工业标准。用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

sql有6个部分:

dql 查询,从表中获取数据;

dml:数据操作语言,就是添加、修改、删除表中的数据;(开发写好,运维执行)

tpl:dml的数据能更新到数据库里面或者失效,例如:commit,rollback,在oracle默认dml是不提交数据库的,必须commit,但是在mysql是默认提交的,可以手工打开或者关闭;

dcl:数据控制语言,grant,revoke;  (运维常用)

ddl:数据定义语言,create,drop,alter  ;(运维常用)

ccl:指针控制语言,declare等

7.mysql常见管理应用

7.1字符集

1)创建数据库:create databases 数据库名

mysql> create database oldboy;
Query OK, 1 row affected (0.13 sec)
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| oldboy             |
| performance_schema |
| test               |
| wiki               |
+--------------------+
6 rows in set (0.00 sec)
mysql> show create database oldboy\G
*************************** 1. row ***************************
       Database: oldboy
Create Database: CREATE DATABASE `oldboy` /*!40100 DEFAULT CHARACTER SET latin1 */---表示默认字符集是拉丁1
1 row in set (0.06 sec)
  2)之前讲过三种安装mysql的方式,其实每种方式都需要./configure 进行mysql数据库的编译。如果我们在编译安装的时候,没有指定特定的编译安装,那么默认就是拉丁安装,如果指定了比如utf8,那么以后创建对应的数据库就不需要指定字符集了,默认就是utf8。当然,这里有个前提是,数据库在编译的时候要支持创库的字符集,一般情况下默认不配置这个,也是包含了比如utf8,gbk,拉丁等库字符集了。
 
  3)创建一个名为oldboy_gbk字符集数据库;创建一个名为oldboy_utf字符集的数据库;
      mysql> create database oldboy_gbk DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;  ---字符集就是一套编码,字符校对就是比较编码的方式,按照字符集进行读写。
      mysql> create database oldboy_utf8 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
 
  4)企业如何创建数据库呢?
         是根据开发的程序确定的,编译时指定数据库,然后建库的时候默认创建即可,create database oldboy
 
   7.2 建库命令
       1)展示数据库:show  database like %old%
       2)   建立数据库:use  oldbou_gbk
       3) 查询时间:select now();
       4) 删除用户:drop user 'oldboy'@'localhost'
       5)    grant 命令在创建用户,授权:
               grant all on  db1.* to 'user'@'localhost'  identified by  'xxx' 
               show grants for oldgirl@localhost;
        6)允许其他机器机器访问:              
            mysql> create user  test @'192.168.0.%'  identified by 'test';
           [root@djw1 ~]# mysql -utest -ptest -h 192.168.0.102
       7)all privileges都有哪些权限?(企业的安全50%来自内部,运维要控制最小原则)
            REVOKE INSERT ON test.* FROM 'oldboy'@'localhost';
           show grants for oldboy@localhost;
          GRANT SELECT, UPDATE, DELETE, CREATE, DROP, REFERENCES, INDEX, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, EVENT, TRIGGER ON `test`.* TO 'oldboy'@'localhost'
   7.3 表和表语句
     1) 建表语句:
create table student(
 id int(4)  not null,
 name char(20) not null,
 age tinyint(2) not null default '0',
 dept varchar(16)  default null
);
查看:
  | student | CREATE TABLE `student` (
  `id` int(4) NOT NULL,
  `name` char(20) NOT NULL,
  `age` tinyint(2) NOT NULL DEFAULT '0',
  `dept` varchar(16) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
默认情况下,数据库是什么字符集,那么表就是什么字符集,引擎是InnoDB。mysql5.5和5.1的默认引擎是不一样的,mysql5.1及以前默认引擎为MyISAM,现在5.5的引擎是InnoDB.
     2)查看表结构:
       

3)为表的字段创建索引

索引就像书的目录一样,如果在字段上建立索引,那么以索引列为查询条件时,就可以加快速度,很重要。

主键索引查询是最快的。无论建立什么索引,最终都是在表对应的列上创建,可以是单列或者多列上创建索引。

索引分为:主键索引和普通索引,普通索引为唯一索引和不唯一索引。(所谓唯一索引,就是因为有了主键,但是还想区分此列为唯一)

创建索引:

       drop table student;

create table student(

id int(4)  not null AUTO_INCREMENT,
 name char(20) not null,
 age tinyint(2) not null default '0',
 dept varchar(16)  default null,
 PRIMARY KEY (id),
 KEY index_name(name)
);

展示索引:show index from student\G;

创建联合索引:create index ind_name_dept on student(name,dept);

index(a,b,c)仅a,ab,abc三个查询条件列可以走索引,b,bc,ac,c等无法使用索引,这叫做联合索引是有前缀生效特性的。

创建唯一索引:

drop  index index_name on student;
   create unique  index uni_ind_name on student(name);

7.4 索引可以加快查询速度,那么就给所有的列建立索引?

因为索引不但占用系统空间,更新数据库时还需要维护索引重建,因此,索引是一把双刃剑,并不是越多越好,所以数十到百行的小表无需索引,写频繁读少少建立索引。索引 一定要建立在where后的条件上的列,且是唯一值多的大表上创建。

四、linux-mysql 下MySQL的管理(一)的更多相关文章

  1. Linux系统环境下MySQL数据库源代码的安装

    Linux系统环境下MySQL数据库源代码的安装 基本环境:CentOS Linux release 7.8.2003 (Core).MySQL5.6 一.      安装环境准备 若要在Linux系 ...

  2. 解决Linux系统下Mysql数据库中文显示成问号的问题

    当我们将开发好的javaWEB项目部署到linux系统上,操作数据库的时候,会出现中文乱码问题,比如做插入操作,发现添加到数据库的数据中文出现论码,下面就将解决linux下mysql中文乱码问题! 打 ...

  3. linux系统下MySQL表名区分大小写问题

    linux系统下MySQL表名区分大小写问题 https://www.cnblogs.com/jun1019/p/7073227.html [mysqld] lower_case_table_name ...

  4. LINUX系统下MySQL 压力测试工具super smack

    摘要:1.源文件下载地址:http://vegan.net/tony/supersmack/2.安装:注意在编译时,可以先把对应的libmysqlclient.so.*拷贝到/usr/lib3.测试: ...

  5. Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 (需暂停服务的方式)

    Linux系统下 MYSQL数据库中的数据库文件在本机内迁移 本机采用Ubuntu16.04系统,tar方式安装MySQL5.7.21 数据库安装文件夹为    /home/devil/mysql 现 ...

  6. Linux - centos7 下 MySQL(mariadb) 和 主从复制

    目录 Linux - centos7 下 MySQL(mariadb) 和 主从复制 MySQL(mariadb) 安装MySQL(mariadb) 配置数据库的中文支持 在远程用 mysql客户端去 ...

  7. 第一次项目上Linux服务器(四:CentOS6下Mysql数据库的安装与配置(转))

    一.mysql简介 说到数据库,我们大多想到的是关系型数据库,比如mysql.oracle.sqlserver等等,这些数据库软件在windows上安装都非常的方便,在Linux上如果要安装数据库,咱 ...

  8. linux(raspbian)下mysql的安装,权限设置和用户管理

    一 MySQL安装:(1) 使用apt-get安装, 由于raspbian是基于Debian的自由操作系统,debian默认自带apt-get指令安装应用因此可以使用来安装 sudo apt-get ...

  9. 【数据库】4.0 MySQL入门学习(四)——linux系统环境下MySQL安装

    1.0 我的操作系统是CentOS Linux release 7.6.1810  (Core) 系统详细信息如下: Linux version 3.10.0-957.1.3.el7.x86_64 ( ...

  10. Linux(Ubuntu)下MySQL的安装与配置

    转自:http://www.2cto.com/database/201401/273423.html 在Linux下MySQL的安装,我一直觉得挺麻烦的,因为之前安装时就是由于复杂的配置导致有点晕.今 ...

随机推荐

  1. 在Linux下 MySQL错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) 解决办法【很管用】

    一般这个错误是由密码错误引起,解决的办法自然就是重置密码. 假设我们使用的是root账户. 1.重置密码的第一步就是跳过MySQL的密码认证过程,方法如下: #vim /etc/my.cnf(注:wi ...

  2. APP中H5页面调试神器

    Fiddler Web Debugging Tool for Free by Telerik window 可以 下载,然后我的H5 嵌入到 APP 里面就可以快速捕捉到接口啦.不会因为看不见就得靠“ ...

  3. 使用idea断点调试时出现no executable code found at line问题

    问题描述 今天突然碰到了这样的一个问题: 使用断点调试时,断点的地方出现了一个叉号,而不是对勾,这就让我非常无奈了. 调了一天,终于把这个问题解决了,还是要记录一下的. 问题情况如下: 除了这里,de ...

  4. ES6 之 第七种数据类型Symbol

    概述 为了减少对象的属性名冲突,ES6引入新的原始数据类型Symbol,JS的第七种数据类型. Symbol 能够保证每个属性的名字都是独一无二,这样就能从根本上防止属性名冲突. Symbol 值能够 ...

  5. JavaScript 之 web API

    1.获取元素 document.getElementById('标签的id值'); document.getElementsByTagName('标签名'); document.getElements ...

  6. .NET技术-2.0. 操作数据库-Dapper

    .NET技术-2.0. 操作数据库-Dapper 项目参见: 1. 为什么选择Dapper 1) 性能优越: 其实在各大网站上,我们大概都会看到这样的一个对比效果图,在超过500次poco seria ...

  7. KL散度与JS散度

    1.KL散度 KL散度( Kullback–Leibler divergence)是描述两个概率分布P和Q差异的一种测度.对于两个概率分布P.Q,二者越相似,KL散度越小. KL散度的性质:P表示真实 ...

  8. 吴裕雄--天生自然 PHP开发学习:While 循环

    <html> <body> <?php $i=1; while($i<=5) { echo "The number is " . $i . &q ...

  9. CSS 选择器权重计算规则(转)

    其实,CSS有自己的优先级计算公式,而不仅仅是行间>内部>外部样式:ID>class>元素. 一.样式类型 1.行间 <h1 style="font-size: ...

  10. java设计模式--六大原则

    一.单一职责原则 单一职责原则:就一个类而言,应该仅有一个引起它变化的原因.通俗来说,就是互相不相关的属性和方法不要放在一个类中,就好比之前简单工厂模式中介绍的那样,客户端(Customer)应该与工 ...