解决

在日常使用mysqldump进行数据备份时,会出现如下的问题:

mysqldump -h ***  -u root -p --skip-lock-tables mig_test > /var/log/mysql/bak.sql
Enter password:
#输入密码之后报如下错误:
mysqldump: Couldn't execute 'SELECT COLUMN_NAME, 
    JSON_EXTRACT(HISTOGRAM, '$."number-of-buckets-specified"')  
    FROM information_schema.COLUMN_STATISTICS                
    WHERE SCHEMA_NAME = 'mig_test' AND TABLE_NAME = 'migrations';':

Unknown table 'COLUMN_STATISTICS' in information_schema (1109)

经查阅相关资料得知,需要添加--column-statistics=0即可。我猜测的原因可能是备份数据时候在读取相关表结构没有相关权限,所以报此错误。通过添加--column-statistics=0进行关闭,以免报错。

column-statistics解释

--column-statistics 是一个用于输出列统计信息的选项。这个选项可以让 mysqldump 在备份数据时,输出每个表的列名、数据类型、长度、默认值、是否为 null 等信息,同时还输出了每个列的统计信息,包括平均长度、总长度、字符集、数字类型的比例等信息。

列统计信息对于优化备份文件的大小和速度非常有用。例如,如果你知道某个列中大多数数据都是 NULL,那么你可以减少备份该列的数据,从而减少备份文件的大小。另外,如果你知道某个列的数据类型和长度,你可以更好地规划备份文件的大小和格式,以最大化备份效率。

[方式一] 配置ssh实现免密登录

本地需要安装OpenSS扩展

第一步 通过终端生成rsa key

ssh-keygen -t rsa -C "your_email@example.com"  

your_email@example.com 是你自己的邮箱域名,该命令一路回车,生成一对rsa密钥并将电子邮件地址设置为“your_email@example.com”,你git仓库使用的邮箱与此对应。

第二步 git中设置密钥

git config --global core.sshCommand "openssh-client -o StrictHostKeyChecking=no -i /path/to/your/key.pem"  
  1. --global 参数代表全局使用,不全局使用则需要进入对应本地仓库目录进行设置

  2. /path/to/your/key.pem 是你的私钥

或将SSH密钥添加到ssh-agent

  • 在后台启动 ssh 代理
eval "$(ssh-agent -s)"
  • 添加私钥
ssh-add ~/.ssh/私钥

第三步 远程仓库设置公钥

远程仓库如github,gitlab 会有一个设置保存ssh地方,将你的公钥也就是.pub结尾的复制上去便可!

git的ssh和linux ssh免密登录是原理一致的!

[方式二] 使用credential.helper

credential.helper 参数配置用于指定 Git 在连接远程服务器时使用的密码存储程序。默认情况下,Git 使用 ~/.ssh/id_rsa.pub 文件存储密码,但可以使用 store 选项来更改该默认设置。

credential.helper=store 将使用密码存储程序来存储远程服务器的用户名和密码,以便在以后使用。命令如下:

git config  credential.helper 'store'    

接下来默认只需要第一次登录使用密码之后,就会记住密码,下次无需在使用密码登录!

清除密码

git config  credential.helper null

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 定义动态数组结构体
typedef struct {
    void** data;    // 数据
    int size;       // 大小
    int capacity;   // 容量
} Array;

// 初始化动态数组
void initArray(Array* arr, int capacity) {
    arr->data = (void**)malloc(capacity * sizeof(void*));
    arr->size = 0;
    arr->capacity = capacity;
}

// 释放动态数组
void freeArray(Array* arr) {
    free(arr->data);
    arr->size = 0;
    arr->capacity = 0;
}

// 向动态数组中添加一个元素
void push(Array* arr, void* element) {
    if (arr->size == arr->capacity) {
        arr->capacity *= 2;
        arr->data = (void**)realloc(arr->data, arr->capacity * sizeof(void*));
    }
    arr->data[arr->size++] = element;
}

// 从动态数组中删除一个元素
void removeElement(Array* arr, int index) {
    if (index < 0 || index >= arr->size) {
        return;
    }
    arr->size--;
    for (int i = index; i < arr->size; i++) {
        arr->data[i] = arr->data[i + 1];
    }
}

// 根据索引从动态数组中获取一个元素
void* get(Array* arr, int index) {
    if (index < 0 || index >= arr->size) {
        return NULL;
    }
    return arr->data[index];
}

int main() {
    Array arr;
    initArray(&arr, 10);
    int a = 10, b = 20, c = 30;
    push(&arr, &a);
    push(&arr, &b);
    push(&arr, &c);
    for (int i = 0; i < arr.size; i++) {
        printf("%d ", *((int*)get(&arr, i)));
    }
    printf("\n");
    removeElement(&arr, 1);
    for (int i = 0; i < arr.size; i++) {
        printf("%d ", *((int*)get(&arr, i)));
    }
    printf("\n");
    freeArray(&arr);
    return 0;
}

上面code中使用了动态数组来表示类似于PHP的array数据类型。动态数组包含一个void指针数组和数组的大小和容量。使用realloc函数来实现动态扩容。在添加元素时,先判断数组是否已满,如果已满则动态扩容。在删除元素时,将数组中的元素向前移动一个位置,覆盖掉要删除的元素。在获取元素时,根据索引返回相应的元素。需要注意的是,由于数组中的元素是void指针类型,因此需要进行类型转换后才能使用。

这种实现方式可以用于存储任意类型的数据,包括基本类型、结构体、指针等。但需要注意的是,由于C语言中没有自带的动态类型或泛型机制,因此在使用动态数组时需要手动进行类型转换和类型检查,否则可能会导致程序出错或崩溃。

1. 查看所有本地分支:

git branch

2. 删除本地分支:

git branch -D branch_name

其中,branch_name为要删除的分支名称。

3. 查看所有远程分支:

$ git branch -r

4. 删除远程分支:

git push origin --delete branch_name

如果要批量删除本地分支,可以使用以下命令:

git branch | grep -v "main" | xargs git branch -D

其中,”main”为要保留的分支名称,可以根据需要进行修改。

如果要批量删除远程分支,可以使用以下命令:

git branch -r | grep -v "main" | sed 's/origin\//:/' |  xargs git push

main为要保留的分支名称,可以根据需要进行修改。最后一个命令中的sed命令是将远程分支名中的origin/替换为:/,因为git push命令中需要使用的远程分支名不包含origin/