自学内容网 自学内容网

网络编程-UDP以及数据库mysql

UDP通信流程
服务端客户端
有一个邮箱socket()有一个邮箱socket()
绑定地址bind()发送数据sendto
接收数据recvfrom关闭close()
关闭colse()
//服务端
#include "head.h"
// ./server 10001
int main(int argc,char *argv[])
{
    // 1、创建socket套接字
    // 参数1:代表IPV4
    // 参数2:数据报套接字 -- UDP
    // 参数3:通常为0
    int udp_fd = socket(AF_INET, SOCK_DGRAM, 0);
    if (udp_fd < 0)
    {
        perror("socket error!\n");
        return -1;
    }

    // 2、给服务端绑定一个IP地址和端口号,方便与客户端进行数据通信。
    struct sockaddr_in addr;
    addr.sin_family = AF_INET;     //地址族: IPV4
    addr.sin_port = atoi(argv[1]); // 端口号
    //inet_pton(AF_INET, "127.0.0.1", (struct in_addr*)&addr.sin_addr);
    addr.sin_addr.s_addr = htonl(INADDR_ANY); // 绑定服务端IP地址
    bind(udp_fd, (struct sockaddr*)&addr, sizeof(addr));

    // 3、循环接收客户端的数据
    char buf[100];
    struct sockaddr_in cli_addr;
    int len = sizeof(cli_addr);
    while(1)
    {
        bzero(buf, sizeof(buf));
        recvfrom(udp_fd, buf, sizeof(buf), 0, (struct sockaddr*)&cli_addr, &len);
        if (strcmp(buf, "quit") == 0)
        {
            break;
        }
        printf("from client: %s\n", buf);
    }

    // 4、关闭套接字
    close(udp_fd);
    printf("finish!\n");

    return 0;
}

//客户端
#include "head.h"
// ./client 10001
int main(int argc,char *argv[])
{
    // 1、创建socket套接字
    // 参数1:代表IPV4
    // 参数2:数据报套接字 -- UDP
    // 参数3:通常为0
    int sfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (sfd < 0)
    {
        perror("socket error!\n");
        return -1;
    }

    // 2、设置将要与之通信的服务端的IP地址和端口号,
    struct sockaddr_in addr;
    addr.sin_family = AF_INET;     //地址族: IPV4
    addr.sin_port = atoi(argv[1]); // 端口号
    inet_pton(AF_INET, "127.0.0.1", (struct in_addr*)&addr.sin_addr);

    // 循环接收客户端的数据
    char buf[100];
    while(1)
    {
        // 手动输入一个数据
        bzero(buf, sizeof(buf));
        fgets(buf, sizeof(buf), stdin);
        if (strcmp(buf, "quit") == 0)
        {
            break;
        }

        // 将输入的数据发送
        sendto(sfd, buf, sizeof(buf), 0, (struct sockaddr*)&addr, sizeof(addr));
    }

    // 3、关闭套接字
    close(sfd);
    printf("finish!\n");

    return 0;
}

#### 网络通信IO模式

- 阻塞模式

  - `read\recv\recvfrom`原本默认属性就是阻塞模式
  - 阻塞模式不是由函数本身导致,而由文件属性决定
  - 阻塞模式对于CPU资源的消耗小于非阻塞模式

- 非阻塞模式

  - 获取原属性

    `int status = fcntl(fd, F_GETFL);`

  - 新增属性

    `status |= O_NONBLOCK;`

  - 重新设置属性

    `fcntl(fd, F_SETFL, status);`

- 信号触发

  - 注册`SIGIO`信号,当产生信号时执行对应的函数

    `signal(SIGIO,fun);`

  - 当`SIGIO`信号产生时,当前进程可以捕捉

    // 设置有`sfd`套接字输入输出状态改变出发的`SIGIO`

    // 简而言之:就是设置`SIGIO`的来源是套接字,而非其他`IO`

    `fctnl(sfd, F_SETOWN,getpid());`

  - 设置服务端套接字为异步模式

    1. 获取原属性

       `int status = fcntl(fd, F_GETFL);`

    2. 新增属性

       `status |= O_NONBLOCK;`

    3. 重新设置属性

       `fcntl(fd, F_SETFL, status);`

- 多路复用

  - 解决的问题:(==用于监测多个套接字的`IO`状态==)以非阻塞的方式检查文件描述符上是否进行`IO`操作。同时检查多个文件描述符,看其中的任意一个是否执行`IO`操作。
  - 目标:同时==监测==多个文件描述符的状态,查看`IO`系统调用是否可以非阻塞的执行
  - `select`技术是一种非阻塞方式,使用`select`方式工作的进程或线程可以==监视==我们需要监视的文件描述符的变化情况

## 数据库

#### 数据库概念及作用

概念:是一种数据管理软件,形成无冗余数据,同时提供访问接口

作用:存储和管理数据

#### 数据库核心

数据库管理系统(`DBMS`)

`DBMS`提供了很多功能,可通过`SQL`来定义和操作数据,维护数据的完整性和安全性,以及各种数据库管理

#### `SQL`结构化查询语言

`DDL`    数据定义语言    定义和管理数据对象,如数据库、数据表

`DML`    数据操作语言    用于操作数据库中包含的数据

`DQL`    数据查询语言    用于数据库数据查询

`DCL`    数据控制语言    用于管理数据库的语言,包含管理权限及数据更改

#### 数据库的管理(分层管理)

库:`database`

表:`table`

字段:一列表示一个字段

记录:一行表示一条记录

#### 数据库的安装及验证

安装
sudo apt-get install mysql-server mysql-client//数据库的服务端及客户端数据库的开发软件包
sudo apt-get install libmysqlclient-dev//数据库的开发软件包
查看以安装数据库的版本 
mysql --version

    
    
    
    
登录
    mysql -u root -p   // 登录本机使用当前这条命令即可
    mysql -u root -p1  // 1代表密码,跟-p之间没有空格;当前方式不会使用

    
    
    
    
登录远程数据库
    语法:mysql -h 主机名/IP地址 -u 用户名 -p
    示例1:mysql -h 192.168.14.61 -u root -p1
    示例2:mysql -h st-virtual-machine -u root -p1
    示例3:mysql -h localhost -u root -p1
    示例4:mysql -h 127.0.0.1 -u root -p1

    
    
    
    
退出
    exit
    quit
MYSQL数据库操作
查询已经存在的数据库
    所有数据库命令要以;或\g结束
    show databases;
    show databases\g
        

        
        
       
创建数据库
    语法:create database [if not exists] 数据库名称
    create database XA2407
    
    命名规则
    必须合法,不得同名
    名称可以由任意字母、数字、"_"、"$"组成,可以是上述任意字符开头,但是不能全部为数字
    

        
        
        
删除数据库
    语法:drop database [if exists] 数据库名称;
    示例1:drop database XA2407
    

        
        
        
切换数据库
    语法:use 数据库名称
    示例:use XA2407

表结构

1、查询表
    show tables;





2、创建表
    语法:create table [if not exists] 表名(字段名1 类型 [约束条件], .....);

    字段数据类型:
        数值型      (常用:tinyint, int, float)
        字符串型    (常用:varchar, blob, text)
        时间日期型   (常用:date, time, datetime)
        
    六大约束条件:
        主键约束(primary key)        用于唯一表示记录
        唯一约束(unique key)         设置字段的值是唯一的
        非空约束(not null)           字段值不允许为空
        自增约束(auto_increment)     在一个值的基础上自增1(只能修饰整型字段)
        外键约束(foreign key)        设置为其它表的外键
        默认约束(default)            设置字段的默认值     
        
    示例1: create table if not exists person(id int, name varchar(20), age int);
    示例2: create table person1(id int primary key, name varchar(20), age int);
    示例3: create table person2(id int primary key, name varchar(20) not null, age int default '18');
    示例4: create table person3(id int, name varchar(20)) default charset=utf8;





3、查看表结构
    示例1:describe 表名;
    示例2:desc 表名;
    示例3:show create table 表名;





4、删除表
    语法:drop table 表名;





5、表结构操作
    修改表名
    语法:alter table 旧表名 rename [to] 新表名;
    示例1:alter table person rename AAAA;
    示例2:alter table AAAA rename to BBBB;

    添加字段
    在表的最后一个位置添加字段
    语法:alter table 表名 add 字段名 字段类型 [约束条件];
    示例1:alter table BBBB add score float;
    示例2:alter table BBBB add score1 float not null;
    在表的第一个位置添加字段
    语法:alter table 表名 add 字段名 字段类型 [约束条件] first;
    示例1:alter table BBBB add address varchar(20) first;
    示例2:alter table BBBB add sex varchar(20) not null first;
    在表的指定位置添加字段
    语法:alter table 表名 add 字段名 字段类型 [约束条件] after 字段名;
    示例1:alter table BBBB add ttt varchar(20) after id;
    示例2:alter table BBBB add yyy varchar(20) not null after name;

    修改字段名称和类型
    语法:alter table 表名 change 旧字段名 新字段名 字段类型;
    示例1:alter table BBBB change ttt new_feild varchar(20);
    示例2:alter table BBBB change yyy qqqq float;
    示例3:alter table BBBB change new_feild new_feild float;
    备注1: 如果“新字段名”与“旧字段名”相同, 而类型不同,则相当于是修改类型。
    备注2: 如果“新字段名”与“旧字段名”的类型相同, 而名称不同,则相当于是修改字段名称。

    修改字段数据类型
    语法:alter table 表名 modify 字段名 新字段类型;
    示例1:alter table BBBB modify name blob;

    修改字段顺序
    将字段移动到第一行
    语法:alter table 表名 modify 字段名 新字段类型 first;
    示例1:alter table BBBB modify qqqq float first;
    将字段移动到某字段之后
    语法:alter table 表名 modify 字段名1 字段类型 after 字段名2;
    示例1:alter table BBBB modify address varchar(20) after socre;
    示例2:alter table BBBB modify sex tinyint after socre1;
    //备注:如果字段类型与原字段类型不同,相当于修改字段类型的同时又调整了字段顺序

    删除字段
    语法:alter table 表名 drop 字段名;
    示例1:alter table BBBB drop qqqq;

    表创建后,设置对字段约束条件的修改/增加
    增加字段主键/唯一约束(primary key/unique key)
        语法:alter table 表名 add 约束条件(字段名)
        示例:alter table BBBB add primary key(age)
     增加字段非空约束(not null)
        语法:alter table 表名 modify 字段名 字段类型 约束条件;
        示例:alter table BBBB modify sex tinyint not null;
    设置默认约束(default)
            语法:alter table 表名 alter 字段名 set default '默认值';
            示例:alter table BBBB alter new_feild set default '1.35';
     设置外键约束(foreign key)
            语法:在创建表的时候:外键的创建语法如下:
            constraint 外键名 foreign key 字段名1[,字段名2...] references 主表名 主键列1[,主键列2...]
            示例:
            create table tb_dept (id int PRIMARY KEY,name varchar(10),locate varchar(50));
            create table tb_emp (id int PRIMARY KEY,name varchar(10),dpt_id int,Salary float, CONSTRAINT fk_dept_id FOREIGN KEY(dpt_id) REFERENCES  tb_dept(id));      
            语法:在表创建后:外键的创建语法如下:
            ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY(字段) REFERENCES 主表名(主键列) [ON DELETE 参数];
       增加字段并设置为自增约束
            语法: alter table 表名 add column 新字段 新字段类型 auto_increment primary key;
            示例: alter table BBBB add column nnnn tinyint auto_increment primary key;

表创建后,对于字段约束条件的删除
        取消主键/外键约束(primary key/foreign key)
            语法:alter table 表名 drop 约束条件;
            示例:alter table BBBB drop primary key;
        取消唯一约束(unique key)
            语法:alter table 表名 drop index 字段名;
            示例:alter table BBBB drop index id;
        取消默认约束(default)
            语法:alter table 表名 alter 字段名 drop default;
            示例:alter table BBBB alter new_feild drop default;
        取消非空/自增约束(not null / auto_increment)
            语法:alter table 表名 modify 字段名 字段类型;
            示例1:alter table BBBB modify sex tinyint;

修改字符集
        修改表和所有数字段的字符集
            语法:alter table 表名 convert to character set utf8;
            示例:alter table BBBB convert to character set utf8;
        修改表中指定字段的字符集
          语法:alter table 表名 change 字段名 字段名 字段类型 character set utf8;
          语法:alter table BBBB change address address varchar(20) character set utf8;
数据操作
1、添加数据
    单条插入(非空字段、主键字段在插入数据时不可被省略)
    语法:insert into 表名 [(字段1, 字段2, 字段3, …)] values(值1,值2,值3,…);
    示例1:insert into BBBB (id,name,socre1,sex) values(1,'0101',1.22,15);
    示例2:insert into BBBB values(1,'0101',1.22,15);
    示例3:insert into BBBB (id,socre1) values(2,2.22);
    
    批量插入
    语法:insert into 表名 [(字段1,字段2,字段3,…)] values(值11,值21,值31,…), (值12,值22,值32,…),…;
    示例1:insert into BBBB (id,name,socre1,sex) values(1,'0101',1.22,15),(2,'0202',2.22,25),(3,'0303',3.22,35);
    示例2:insert into BBBB values(1,'0101',1.22,15),(2,'0202',2.22,25),(3,'0303',3.22,35);
    示例3:insert into BBBB (id,socre1) values(5,5.22),(6,7.22);
    




2、删除数据
    删除特定数据
    语法:delete from 表名 where  条件;
    示例1:delete from BBBB where name='0101';
    
    删除全部数据
    语法:delete from 表名;
    示例1:delete from BBBB; 





3、更新数据
    更新字段中所有的数据
    语法:update 表名 set 字段1=值1, 字段2=值2, 字段3=值3, …;
    示例:update BBBB set name='1234';
    
    更新特定数据
    语法:update 表名 set 字段1=值1,字段2=值2, 字段3=值3,… where 条件;
    示例1:update BBBB set id=100 where id=3;
    示例2:update BBBB set id=100 where socre1>5;
    示例3:update BBBB set id=123 where sex is null;
    
    



4、查询数据
    查询所有数据
    语法:select * from 表名;
    示例:select * from BBBB;

    查询指定字段数据
    语法:select 字段1,字段2... from 表名;
    示例:select id,sex from BBBB;  
    
    查询数据时去除重复数据
    语法:select distinct 字段1,字段2... from 表名;
    示例1:select distinct id from BBBB;
    示例2:select distinct id,sex from BBBB;   
    
    实现数字四则运算数据查询(+ - * / %)
    语法:select 字段 运算符 运算符操作数... from 表名;
    示例1:select id+socre1 from BBBB;
    示例2:select id,socre1, id*socre1 from BBBB;
    示例3:select id,socre1, id*socre1 as total from BBBB;
    示例4:select id as a111, socre1 as b222, id*socre1 as total from BBBB;
    
    设置显示格式的数据查询 CONCAT()
    语法:select 字段 as 字符串 from 表名;
    示例:select id as sss from BBBB;
    语法:select CONCAT(字段1, 字符串, 字段2) from 表名;
    示例:select CONCAT(id,"-->",sex) from BBBB;
    示例:select CONCAT(id,"-->",sex," : ", name) from BBBB;
    示例:select CONCAT(id,"-->",sex," : ", name) as total from BBBB;
    
    限制输出记录的条数
    语法:select * from 表名 limit 起始索引,总显示条数;
    示例:select * from BBBB limit 3,2;

    限制输出记录的条数
    mysql 支持的比较运算符和逻辑运算符
    >,<,=,!=,>=,<=,         AND(&&) ,OR(||),XOR(异或),NOT(!)
        单条件 数据查询
        语法:select 字段 from 表名 where 条件;
        示例:select id from BBBB where id=2;
        示例:select * from BBBB where id=2;

        多条件 数据查询
        语法:select 字段 from 表名 where 条件;
        示例:select * from BBBB where id=2 && sex=25;
        示例:select * from BBBB where id=2 AND sex=25;

        带 between and 关键字的范围查询
        语法:select 字段 … from 表名 where 字段 between 值1 AND 值2
        示例:select * from BBBB where socre1 between 2 AND 4;

        不符合范围的数据查询
        语法:select 字段 … from 表名 where 字段 not between 值1 AND 值2
        示例:select * from BBBB where socre1 not between 2 AND 4;

        带 IS NULL 关键字的空值查询
        语法:select 字段 … from 表名 where 字段名 is null;
        示例:select * from BBBB where sex is null;

        带 IS NOT NULL 关键字的非空值查询
        语法:select 字段 … from 表名 where 字段名 is not null;
        示例:select * from BBBB where sex is not null;
        示例:select * from BBBB where sex is null AND name is not null;

        带IN关键字的集合查询 
        语法:select 字段 … from 表名 where 字段名 in (值1,值2, …)
        示例:select * from BBBB where name in (2, 100);

        带 NOT IN关键字的非集合查询 
        语法:select 字段 … from 表名 where 字段名 not in (值1,值2, …)
        示例:select * from BBBB where name not in (2, 100);

        带 LIKE 关键字的模式查询
            LIKE 关键字支持的通配符 
            “_” : 通配单个字符;
            “%”:  通配任意字符,可以是0个字符,1个字符,或多个字符。
        语法:select 字段 … from 表名 where 字段名 like '值1';
        示例:select * from BBBB where id like '%3';

        排序查询
        语法:select 字段 … from 表名 order by 字段名 ASC/DESC;
              ASC 升序; DESC 降序
        示例:select * from BBBB order by id asc;
        示例:select * from BBBB order by id desc;

        分组查询
        语法:select 字段 … from 表名 group by 字段名 [having 条件];
        示例:select id from BBBB group by id;
        示例:select id, socre1 from BBBB group by id, socre1;
        示例:select sex from BBBB group by sex having sex is null;
        示例:select id, count(socre1) from BBBB group by id, socre1;
        示例:select socre1, count(socre1) from BBBB group by socre1;

        聚合函数查询:
           COUNT函数:统计记录行的总数
              select count(字段名) from 表名;
               注意:如果字段名为 *,计算表中的总行数,不管某字段是否为NULL
               如果指定了具体字段名,会忽略空值的行
           SUM函数:统计某列数据的和
              select sum(字段名) from 表名;
           AVG函数:统计某列数据的平均值
              select sum(字段名) from 表名;
           MAX函数:统计某列数据的最大值
              select max(字段名) from 表名;
           MIN函数:统计某列数据的最小值
              select min(字段名) from 表名;


原文地址:https://blog.csdn.net/LHB15173352347/article/details/143002096

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!