mysql数据库基础

Posted hanlongyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库基础相关的知识,希望对你有一定的参考价值。

搭建数据库mysql服务器,192.168.4.50

//集体装包rpm -Uvh 包名(支持通配符)

 

主流的数据库软件:MYSQL  ORACLA   BDA  SQL  。。

MYSQL已经被甲骨文公司收购是开源的(但不是完全免费的)  ,其他几个都是闭源的

MYSQL可跨平台 

数据库相同版本是装不上的,需要先卸载,否则会有冲突

公司用的mysql多,红帽光旁里集成的是mariadb(mysql是甲骨文的了)

卸载软不要用yum,要用rpm卸载(忽略依赖关系),不然会误珊服务

mysql-community-client-5.7.17-1.el7.x86_64.rpm

//是提供服务命令的包

mysql-community-server-5.7.17-1.el7.x86_64.rpm

//是提供服务的包

装包如果有依赖关系,看提示,再找包名  //yum list | grep 。。。

数据库目录:/var/lib/mysql/

启动服务初始化会在/var/lib/mysql下生成文件夹及文件

客户端访问数据库服务时传递进程数据文件:/var/lib/mysql/mysql.sock

mysql默认端口:3306

配置文件:/etc/my.cnf

日志文件:/var/log/mysqld.log

pid文件:/var/run/mysqld/mysqld.pid

数据库目录、进程 所有者所属组都是mysql

保证客户端可以通过进程把数据写入数据库里

*默认只允许数据库服务自己访问自己  //其他访问要授权

访问方式:命令行(运维人)、第三方软件图形(程序员用)

                                                                

/etc/my.cof   

# For advice on how to change settings please see

# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html

#上面是mysql的官网

[mysqld]

#

# Remove leading # and set to the amount of RAM for the most important data

# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.

# innodb_buffer_pool_size = 128M

#

# Remove leading # to turn on a very important data integrity option: logging

# changes to the binary log between backups.

# log_bin

#

# Remove leading # to set options mainly useful for reporting servers.

# The server defaults are faster for transactions and fast SELECTs.

# Adjust sizes as needed, experiment to find the optimal values.

# join_buffer_size = 128M

# sort_buffer_size = 2M

# read_rnd_buffer_size = 2M

datadir=/var/lib/mysql                   #数据库的目录

socket=/var/lib/mysql/mysql.sock        #客户端访问数据库服务时传递进程数据信息的伪文件(服务启动时才有)

 

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

 

==log-error=/var/log/mysqld.log           #错误日志

==pid-file=/var/run/mysqld/mysqld.pid    #指定文件保存运行服务时进程的pid号

    

 

 

初始密码在/var/log/mysqld.log 里面

#grep password /var/log/mysqld.log    //在:后面

[[email protected] mysql]# mysql -hlocalhost -uroot -p ‘q-whx%4S(sOc‘

第一次进去要改密码:>alter user [email protected]”localhost” identified by “123qqq...A”;  //新版密码有要求

>exit;

改过退出再进去就可以看库了

#mysql -hlocalhost -uroot -p‘123qqq...A‘      //密码复杂度可以修改

  mysql> show databases;

+---------------------------+

|        Database           |

+----------------------------+

| information_schema |

|           mysql               |

| performance_schema|

|             sys                  |

+----------------------------+

4 rows in set (0.00 sec)

 

 

修改密码复杂度:

mysql> show variables like "%password%";

+------------------------------------------------------+--------+

|          Variable_name                               | Value  |

+------------------------------------------------------+--------+

| default_password_lifetime             | 0      |

| disconnect_on_expired_password      | ON     |

| log_builtin_as_identified_by_password  | OFF    |

| mysql_native_password_proxy_users   | OFF    |

| old_passwords                         | 0      |

| report_password                       |        |

| sha256_password_proxy_users         | OFF    |

| validate_password_check_user_name   | OFF    |

| validate_password_dictionary_file       |        |

| validate_password_length              | 8      |  //密码长度,改成6就是6位数

| validate_password_mixed_case_count   | 1      |

| validate_password_number_count       | 1      |

| validate_password_policy               | MEDIUM |   //密码复杂度,改成0就是降低,会变成LOW

| validate_password_special_char_count  | 1      |

+-------------------------------------------------------+--------+

14 rows in set (0.00 sec)

 

改密码复杂度(无要求)

mysql> set global validate_password_policy=0;

Query OK, 0 rows affected (0.00 sec)

改长度6位数

mysql> set global validate_password_length=6;

Query OK, 0 rows affected (0.00 sec)

 

即可改简单密码

mysql> alter user [email protected]"localhost" identified by "123456";

Query OK, 0 rows affected (0.00 sec)

 

[[email protected] mysql]# vim /etc/my.cnf   //写入配置文件中永久配置,不然重启服务会恢复设置,写在[mysqld]下面

[mysqld]

validate_password_policy=0

validate_password_length=6

 

Root]#Systemctl restart mysqld    //重启验证

 

[[email protected] mysql]# mysql -h localhost -u root -p123456   //密码可用

 

 

 

 

数据库就相当于文件夹

也可以直接在/varmysql> 也可以直接在/var/lib/mysql 下创建目录要设置属主和组为mysql)

运行环境的时候网站服务和数据库服务一起用(分两个服务器单独使用)

 

创建库不能用关键字,区分大小写,不能用特殊符号

 

库管理命令:

Show databases;                      //显示已有的库

Use han;                               //切换库

show tables;   //查看已经有的表

Create database han;             //创建库

Show tables;                    //显示已有的表

Drop database han;           //删除库

select database();                 //现实当前所在的库

 

创建库和表

mysql> create database teadb;      

mysql> create table teadb.stuinfo(         //表名为stuinfo,也可写相对路径直接写stuinfo

-> name char(20),                    //名称和设定字符

    -> age int,                            //名称  类型为数字

    -> homeaddr char(50)

    -> );

Query OK, 0 rows affected (0.31 sec)

//先创建库再创建表

 

mysql> select * from teadb.stuinfo;         //查看表信息内容

Empty set (0.01 sec)

 

mysql> insert into teadb.stuinfo values("bob",19,"shenzhen"),("tom",21,"guangzhou");

Query OK, 2 rows affected (0.03 sec)

Records: 2  Duplicates: 0  Warnings: 0

//创建记录   //values:值    //字符要引号

 

mysql> select * from teadb.stuinfo;           //再查看记录

+----------+----------+-------------+

| name   | age  | homeaddr    |

+----------+---------+---------------+

| bob      |   19     | shenzhen   |

| tom      |   21     | guangzhou |

+-----------+---------+-------------+

2 rows in set (0.00 sec)

 

mysql> update teadb.stuinfo set age=35;               //批量改表

 

mysql> update teadb.stuinfo set age=18 where name="bob";    //单独改表

 

mysql> delete from teadb.stuinfo where name="bob";   //删除name=bob的表

 

mysql> delete from teadb.stuinfo;                       //删除所有的表内容

 

mysql> desc teadb.stuinfo;                              //查看表结构

+---------------+------------+--------+--------+----------+-------+

|       Field    | Type       | Null    | Key   | Default | Extra |

+---------------+-------------+-------+--------+----------+-------+

| name         | char(20) | YES  |           | NULL    |         |

| age           | int(11)      | YES  |          | NULL    |         |

| homeaddr | char(50)  | YES  |          | NULL     |         |

+--------------+-------------+-------+--------+-----------+-------+

列名         字段类型        约束条件

 

mysql> drop tables teadb.stuinfo;         //删除表,库还在

 

 

 

字符集 : 中文字符的集合

gb2312 :

utf8  : 可以写的汉字更多

 

mysql> use teadb;

创建表

mysql> create table t1(name char(10));

mysql> create table t2(name char(10));

 

mysql> show tables;   //查看已经有的表

+---------------------+

| Tables_in_teadb |

+---------------------+

|          t1              |

|          t2              |

+---------------------+

 

mysql> show create table t2;            //查看表的字符类型

+-------+-------------------------------------------------------------------------------------------+

| Table | Create Table                                                                              |

+-------+-------------------------------------------------------------------------------------------+

| t2    | CREATE TABLE `t2` (

  `name` char(10) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1 |    //默认字符类型

+-------+-------------------------------------------------------------------------------------------+

1 row in set (0.00 sec)

 

mysql> create table 学生表(姓名 char(20),性别 char(6))DEFAULT CHARSET=utf8;                //创建中文表,指定字符类型为utf8

 

mysql> insert into 学生表 values("李斯","男"),("赵高","女");  //创建记录

 

mysql> select * from 学生表;

+---------+----------+

| 姓名   | 性别   |

+---------+----------+

| 李斯   | 男     |

| 赵高   | 女     |

+---------+----------+

2 rows in set (0.00 sec)

 

 

浮点型

创建t3表

mysql> create table t3(

    -> age tinyint unsigned ,

    -> pay float(7,2)

    -> );

Query OK, 0 rows affected (0.22 sec)

//float(7,2)7位数2位小数

范围99999.99~ -99999.99

mysql> insert into t3 values(18,38000.88);

mysql> select * from t3;

+------+--------------+

| age  |      pay      |

+------+--------------+

|   18 |  38000.88 |

+------+--------------+

1 row in set (0.00 sec)

 //存什么数要考虑好,超过设置最大宽度存不上.

 

字符类型

一个英文字母就是一个字符

变长:输入多少就用多少不补空格(需要计算,会变慢)

varchar必须指宽度,否则报错

用的多的是char,char不指宽度默认宽度是1,速度快

 

mysql> create table t4(name char(4),homedir varchar(6));

mysql> desc t4;                            //查看表结构

+----------+---------------+-------+------+-------------+-------+

| Field   | Type            | Null   | Key | Default   | Extra |

+----------+----------------+-------+-----+-------------+-------+

| name   | char(4)        | YES  |       | NULL      |           |

| homedir | varchar(6) | YES  |        | NULL     |          |

+-----------+----------------+------+------+------------+-------+

//存超过设定的字符会报错

 

 

时间的用法

mysql> create table t5(name char(10),

    -> birthday date,

    -> start year,

    -> uptime time,

    -> party datetime

    -> );

 

mysql> insert into t5 values("bob",19930702,1993,083000,20181015203000);

 

mysql> select * from t5;

+--------+--------------+---------+-----------+---------------------------+

| name | birthday    | start    | uptime   |           party               |

+------+----------------+---------+------------+---------------------------+

| bob  | 1993-07-02 |  1993  | 08:30:00 | 2018-10-15 20:30:00 |

+------+----------------+---------+------------+----------------------------+

//时间类型赋值一一对应

 

枚举

mysql> create table t6(

    -> name char(10),

    -> likes set("eat","sleep","game","file"),

    -> sex enum("boy","girl","no"));

//设定值

mysql> insert into t6 values("bob","eat,sleep","boy");            //赋值,如果赋没有的值会报错

 

mysql> select * from t6;

+-------+-------------+------+

| name | likes     | sex |

+-------+-------------+------+

| bob  | eat,sleep | boy |

+-------+-------------+------+

 

 

以上是关于mysql数据库基础的主要内容,如果未能解决你的问题,请参考以下文章

MySQL数据库基础+ 数据库的基本操作?

mysql数据库之mysql基础命令

MySQL入门基础一-Mysql的基础体系架构

Mysql基础1

mysql基础学习笔记

mysql基础学习笔记