1.ubuntu18.04上安装mysql,详情查阅转载:

2.进入mysql

mysql -uroot -p ---输入密码后进入mysql

2.创建数据库

create database test;

3.创建表

create table dataset_video(filename varchar(128),duration float,label varchar(128),width int(11),height int(11),code_rate int(11),frame_rate float,package_format  varchar(11),code_format varchar(11) )character set=utf-8

创建后发现还需要添加两个字段ID和path,于是添加这两个字段:ALTER table dateset_video ADD (ID varchar(32) path text) character set=utf8;

但发现位置放在了最后,我希望位置是前两个,试了把ID放在第一位但是都不成功,后来曲线救国,删除了ID,重新添加在first,path放在了ID的后面,如下:

显示表结构:show full columns from dataset_video;

删除字段:alter table dataset_video drop column ID;

增加字段在首位:alter table dataset_video add column ID varchar(32) NOT NULL first;

把ID设为主键:alter table dataset_video addprimary key(ID);(主键要求NOT NULL)

调整表中字段位置:alter table dataset_video change path  path text after ID;

修改字段类型:alter  table dataset_video  modify  column duration  float;

NULL

4.导入库内容的准备工作

开始尝试导入csv和excel都不行,导入的除了ID其他都是NULL,于是查资料发现个很好的博客文章:转载。

把之前的csv进行备份,操作的那份进行另存为unicode文本(txt),用notepad++打开保存的txt文本,修改编码格式为utf-8, 把标题行删除只留数据行,放到服务器上

5.导入(txt文件中数据导入到mysql,字段内容要对应)

执行导入命令:

load data infile '/home/lq/mysql_video.txt' into table dataset_video lines terminated by '\r\n';

报错:ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement

原来是权限问题,查看show global variables like '%secure_file_priv%'; (mysql下),得到

+------------------+-----------------------+
| Variable_name    | Value                 |
+------------------+-----------------------+
| secure_file_priv | /var/lib/mysql-files/ |
+------------------+-----------------------+

secure_file_priv 为 NULL 时,表示限制mysqld不允许导入或导出。

secure_file_priv 为 /tmp 时,表示限制mysqld只能在/tmp目录中执行导入导出,其他目录不能执行。

secure_file_priv 没有值为空''时,表示不限制mysqld在任意目录的导入导出。

但我试图在/etc/mysql/my.cnf中添加secure_file_priv='',重启mysql服务,但是还是不生效,最后这样解决的:加了个local

mysql> load data localinfile '/home/realai/liqing/mysql_video.txt' into table dataset_video lines terminated by '\r\n';

但在我尝试导出数据库中数据到txt时在哪儿加local都不行了,只好屈服导出到secure_file_priv的这个目录了/var/lib/mysql-files/

select * from dataset_video into outfile '/var/lib/mysql-files/test_out.txt' fields terminated by ',' optionally enclosed by '"';   或者命令

select * into outfile '/var/lib/mysql-files/test_out1.txt' from dataset_video limit 10;

续:2020.12.11

6.解决数据库中中文内容显示乱码的问题

问题:发现我导入的数据中的中文成乱码了

解决方法:

show   variables   like   "%char%";
+--------------------------------------+----------------------------+
| Variable_name                        | Value                     |
+--------------------------------------+----------------------------+
| character_set_client                 | utf8                      |
| character_set_connection             | utf8                   |
|character_set_database               | latin1               |
| character_set_filesystem             | binary                  |
| character_set_results                | utf8                       |
| character_set_server                 | latin1                  |
| character_set_system                 | utf8                      |
| character_sets_dir                   | /usr/share/mysql/charsets/ |
| validate_password_special_char_count | 1                  |

需要由latin1修改为utf-8

set character_set_server=utf8;

set character_set_database=utf8;

这是再重新导入数据,中文不是乱码了

但注意mysql重启好后又恢复成latin1了,从网上找了改配置文件的方法但是不生效,还需要继续找解决办法。