(9)Mysql的编译安装和基本语法

前言:

   数据库一般是用来存储用户账户数据,类似于一种表格软件。数据库可以使用php连接,做账户匹配和认证,如我们登录qq,微信会使用一个账户登录,而这个账户就是储存在数据库中的,绑定了身份证号码的信息会填写到数据库中。

1、mysql的安装

1.1、关掉防火墙和selinux,做时间同步,主机命名为mysql.example.com

[root@node3 ~]# hostnamectl set-hostname mysql.example.com
[root@node3 ~]# bas

1.2、mysql所需要的安装包

# yum -y install chrony tar libncurses* libaio lrzsz

[root@mysql ~]# 
[root@mysql ~]# useradd -r -M -s /sbin/nologin mysql    创建mysql用户给数据库使用
[root@mysql ~]# mkdir /opt/software    创建压缩包存放的目录
[root@mysql ~]# mkdir /opt/data/ -p   创建数据库存放数据的目录
[root@mysql ~]# chown -R mysql.mysql /opt/data/  更改所有者和所属组

mysql安装包在官方下载就行了

使用Xshell软件,将mysql安装包拖到/opt/software目录下面

[root@mysql software]# tar -zxvf mysql-5.7.37-linux-glibc2.12-x86_64.tar.gz -C /usr/local/   -C指定解压到/usr/local目录
[root@mysql software]# cd /usr/local/
[root@mysql local]# ln -sv mysql-5.7.37-linux-glibc2.12-x86_64/ mysql 制作软连接,重命名为mysql,也可以使用move,但是那样出错恢复不了

1.3、初始化数据库

[root@mysql mysql]# /usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --datadir=/opt/data  指定储存数据的目录并初始化数据库

[root@mysql mysql]# ln -sv /usr/local/mysql/include/ /usr/local/include/mysql

[root@mysql mysql]# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
[root@mysql mysql]# ldconfig

[root@mysql ~]# vim /etc/my.cnf  写入下面的信息

[mysqld]
basedir = /usr/local/mysql
datadir = /opt/data
socket = /tmp/mysql.sock
port = 3306
pid-file = /opt/data/mysql.pid
user = mysql
skip-name-resolve

[root@mysql ~]# vim /usr/local/mysql/support-files/mysql.server    写入路径

46 basedir=/usr/local/mysql
 47 datadir=/opt/data

[root@mysql ~]# vim /usr/lib/systemd/system/mysqld.service   可以使用systemctl管理mysql服务

[Unit]
Description=mysql server daemon
After=network.targe

[Service]
Type=forking
ExecStart=/usr/local/mysql/support-files/mysql.server start
ExecStop=/usr/local/mysql/support-files/mysql.server stop
ExecReload=/bin/kill -HUP \$MAINPID

[Install]
WantedBy=multi-user.target

 

#echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile   写入环境变量,可以使用mysql命令,在终端。
#source /etc/profile

[root@mysql ~]# mysql -uroot -e "set password=password('123')"
[root@mysql ~]# mysql -uroot -p123

2、数据库基础语法

2.1、增删查改

加粗有颜色的是可以改的数据,剩下的是语法结构

insert:插入

语法结构:insert into 表名(字段,字段2)value(信息,信息)

delete:删除

update:更改

select:查看

alter:修改字段

alter table xx add yyy varchar(30) not null;

alter table xx change yyy zzz varchar(10);

alter table xx drop yyy;

其实使用最多的可以是查,因为一般数据库的数据是不能改的。

增(INSERT)、删(DELETE)、改(UPDATE)、查(SELECT)

show:查看,后面接数据库,引擎等

create:创建表,数据库,用户等

> create table sx(id int not null,name varchar(30) not null,age tinyint);    ----创建一张表

use:使用数据库,切换数据库

grand:权限赋予

所有命令以分号结尾

2.2数据库student,创建表xs,插入一条命令为列

mysql> show databases;

mysql> create database student;
Query OK, 1 row affected (0.01 sec)  显示ok就代表执行成功

>use student;        ---------使用student数据库    

> select database();    -------查看当前数据库

mysql> create table sx(id int not null,name varchar(30) not null,age tinyint);        ----------创建一张xs表,有id,name,age三个可以填信息的模板,语法结构就是没有加粗的部分,加粗的可以他、任意改变

>insert:insert into xs(id,name,age) value (1,'tom',20);    ---------在数据库中插入一张表

mysql> select * from sx;       -------查看xs表中的数据为空

mysql> desc sx;       --------查看表的结构,有哪些字段

mysql> insert into sx (id,name,age) value (2,'laiyingx',8);     ---插入一条数据

>select * from sx;     ----查看全部,表里面填写的内容

mysql> update sx set age = 30 where name = 'tom';   更新tom的年龄

mysql> create user 'cy'@'%';     ----创建cy用户,所有主机都可以远程登录

mysql> delete from sx where id = 1;   -----删除表中的数据

mysql>  delete from sx;  ------删除表中的全部内容

mysql> drop table if exists sx;   ----删除存在的表sx

mysql> drop database if exists student;   -----删除数据库student

>exit;   ----退出数据库

3、题目一

mysql> create database student;

mysql> use student;

mysql> create table cy(id int,name varchar(30),age tinyint);

mysql> desc cy;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | YES  |     | NULL    |       |
| name  | varchar(30) | YES  |     | NULL    |       |
| age   | tinyint(4)  | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+

mysql> insert into cy(id,name,age) value (1,'tom',20);

mysql> select * from cy;
+------+-------------+------+
| id   | name        | age  |
+------+-------------+------+
|    1 | tom         |   20 |
|    2 | jerry       |   23 |
|    3 | laiyingx    |   25 |
|    4 | sean        |   28 |
|    5 | zhangsan    |   26 |
|    6 | zhangsan    |   20 |
|    7 | lisi        | NULL |
|    8 | chenshuo    |   10 |
|    9 | wangwu      |    3 |
|   10 | qiuxiaotian |   20 |
+------+-------------+------+

5.修改lisi的年龄为50

>update cy set age=50 where name='lisi';
6.以age字段降序排序

select * from cy order by age desc;
7.查询student表中年龄最小的3位同学跳过前2位

select * from cy order by age limit 2,1;
8.查询student表中年龄最大的4位同学

 select * from cy order by age limit 6,10;
9.查询student表中名字叫zhangshan的记录

select * from cy where name='zhangsan';
10.查询student表中名字叫zhangshan且年龄大于20岁的记录

select * from cy where name='zhangsan' and age>20;
11.查询student表中年龄在23到30之间的记录

select * from cy where age between 23 and 30; 
12.修改wangwu的年龄为100

update cy set age=100 where name='wangwu';
13.删除student中名字叫zhangshan且年龄小于等于20的记录

delete from cy where name='zhangsan' and age>=20;

  • 8
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值