mysql重置自增长ID 方法一,执行SQL: truncate table test; (这里假定你的表名test,会删除本表,新插入时ID才重新开始) 这种方法好处是运行速度超快 方法二,执行如下SQL: (还是假定表名是test) delete from test;(删除所有数据,但自增长未解决) alter table `test` auto_increment=1; 这种方法好处是可以从任何值开始,缺点是如果数据量大的话delete from test;非常耗时 注意: 当导入文件出现空行时,可将空行删除,再将其自增长id修改即可 ############################################################################## mysql命令行参数 一,mysql命令行参数 Usage: mysql [OPTIONS] [database] //命令方式 -?, --help //显示帮助信息并退出 -I, --help //显示帮助信息并退出 --auto-rehash //自动补全功能,就像linux里面,按Tab键出提示差不多,下面有例子 -A, --no-auto-rehash //默认状态是没有自动补全功能的。-A就是不要自动补全功能 -B, --batch //ysql不使用历史文件,禁用交互 (Enables --silent) --character-sets-dir=name //字体集的安装目录 --default-character-set=name //设置数据库的默认字符集 -C, --compress //在客户端和服务器端传递信息时使用压缩 -#, --debug[=#] //bug调用功能 -D, --database=name //使用哪个数据库 --delimiter=name //mysql默认命令结束符是分号,下面有例子 -e, --execute=name //执行mysql的sql语句 -E, --vertical //垂直打印查询输出 -f, --force //如果有错误跳过去,继续执行下面的 -G, --named-commands /*Enable named commands. Named commands mean this program's internal commands; see mysql> help . When enabled, the named commands can be used from any line of the query, otherwise only from the first line, before an enter. Disable with --disable-named-commands. This option is disabled by default.*/ -g, --no-named-commands /*Named commands are disabled. Use \* form only, or use named commands only in the beginning of a line ending with a semicolon (;) Since version 10.9 the client now starts with this option ENABLED by default! Disable with '-G'. Long format commands still work from the first line. WARNING: option deprecated; use --disable-named-commands instead.*/ -i, --ignore-spaces //忽视函数名后面的空格. --local-infile //启动/禁用 LOAD DATA LOCAL INFILE. -b, --no-beep //sql错误时,禁止嘟的一声 -h, --host=name //设置连接的服务器名或者Ip -H, --html //以html的方式输出 -X, --xml //以xml的方式输出 --line-numbers //显示错误的行号 -L, --skip-line-numbers //忽略错误的行号 -n, --unbuffered //每执行一次sql后,刷新缓存 --column-names //查寻时显示列信息,默认是加上的 -N, --skip-column-names //不显示列信息 -O, --set-variable=name //设置变量用法是--set-variable=var_name=var_value --sigint-ignore //忽视SIGINT符号(登录退出时Control-C的结果) -o, --one-database //忽视除了为命令行中命名的默认数据库的语句。可以帮跳过日志中的其它数据库的更新。 --pager[=name] //使用分页器来显示查询输出,这个要在linux可以用more,less等。 --no-pager //不使用分页器来显示查询输出。 -p, --password[=name] //输入密码 -P, --port=# //设置端口 --prompt=name //设置mysql提示符 --protocol=name //使用什么协议 -q, --quick //不缓存查询的结果,顺序打印每一行。如果输出被挂起,服务器会慢下来,mysql不使用历史文件。 -r, --raw //写列的值而不转义转换。通常结合--batch选项使用。 --reconnect //如果与服务器之间的连接断开,自动尝试重新连接。禁止重新连接,使用--disable-reconnect。 -s, --silent //一行一行输出,中间有tab分隔 -S, --socket=name //连接服务器的sockey文件 --ssl //激活ssl连接,不激活--skip-ssl --ssl-ca=name //CA证书 --ssl-capath=name //CA路径 --ssl-cert=name //X509 证书 --ssl-cipher=name //SSL cipher to use (implies --ssl). --ssl-key=name //X509 密钥名 --ssl-verify-server-cert //连接时审核服务器的证书 -t, --table //以表格的形势输出 --tee=name //将输出拷贝添加到给定的文件中,禁时用--disable-tee --no-tee //根--disable-tee功能一样 -u, --user=name //用户名 -U, --safe-updates //Only allow UPDATE and DELETE that uses keys. -U, --i-am-a-dummy //Synonym for option --safe-updates, -U. -v, --verbose //输出mysql执行的语句 -V, --version //版本信息 -w, --wait //服务器down后,等待到重起的时间 --connect_timeout=# //连接前要等待的时间 --max_allowed_packet=# //服务器接收/发送包的最大长度 --net_buffer_length=# //TCP / IP和套接字通信缓冲区大小。 --select_limit=# //使用--safe-updates时SELECT语句的自动限制 --max_join_size=# //使用--safe-updates时联接中的行的自动限制 --secure-auth //拒绝用(pre-4.1.1)的方式连接到数据库 --server-arg=name //Send embedded server this as a parameter. --show-warnings //显示警告 二,mysql命令行实例 1,auto-rehash自动补全 说例子前,先说一下,你到google或baidu上面搜一下mysql auto-rehash,然后会出来结果,绝大部分都是一样的,并且内容里面有明显错误。mysqld_safe --user=mysql --auto-rehash &,这个根本就不对,为什么抄袭的人不知道自己测试一下,对于这种人,我也是很无语的。你自己写着玩到也无所谓,但是你会害人的。 [root@BlackGhost zhangy]# mysqld_safe --help |grep rehash 参数选项中根本没有auto-rehash 二种方法可以实现自动补全功能 --------------------------------------- [mysql] #no-auto-rehash auto-rehash --------------------------------------- mysql -u root --auto-rehash --------------------------------------- mysql> use test Database changed mysql> select acc //这里自动补全,只是提示表名,和表里面的字段名,不像php可以提示函数名 account account.acct_num account.amount acct_num 2,-B的用法 D:\xampp\mysql\bin>mysql.exe -uroot -D bak_test -e "show tables;" -B Tables_in_bak_test comment user 3,-E的用法 D:\xampp\mysql\bin>mysql.exe -uroot bak_test -e "show tables;" -E *************************** 1. row *************************** Tables_in_bak_test: comment *************************** 2. row *************************** Tables_in_bak_test: user 4,-D的用法 [root@BlackGhost zhangy]# mysql -u root -D test 进入后默认就在test数据库里面,不要用use test; 5,--default-character-set设置默认字符集 [root@BlackGhost zhangy]# mysql -u root -D test --default-character-set=utf8 6,--delimiter设置mysql命令结束符 [root@BlackGhost zhangy]# mysql -u root -D test --delimiter=\| mysql默认的命令结束符是分号,现在把它设置成竖杠,要注意|前面的\ 7,-e的用法 D:\xampp\mysql\bin>mysql.exe -uroot -D bak_test -e "show tables;" 这个很有用的,因为我不用进入mysql客户里面去,就能把我要的数据取出来,这个可以配合shell脚本的话,能发挥很大的功能 8,-f的用法 D:\xampp\mysql\bin>mysql.exe -uroot bak_test -e "show databaseds;show tables;" - f ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the ma nual that corresponds to your MySQL server version for the right syntax to use n ear 'databaseds' at line 1 +--------------------+ | Tables_in_bak_test | +--------------------+ | comment | | user | +--------------------+ 忽略mysql的错误,继续向下执行 9,-N的用法 D:\xampp\mysql\bin>mysql.exe -uroot bak_test -e "select * from user" -N +---+------+---+ | 1 | bb | 0 | | 2 | tank | 0 | +---+------+---+ 10,-p的用法 [root@BlackGhost zhangy]# mysql -u root -o test -p -S /tmp/mysql.sock Enter password 11,-h的用法 [root@BlackGhost zhangy]# mysql -u root -h 192.168.1.102 服务器可能不只一个,这个时间我们可以用-h来指定连接哪里 12,-H的用法 D:\xampp\mysql\bin>mysql.exe -uroot bak_test -e "show tables " -H
Tables_in_bak_test
comment
user
13,-X的用法 D:\xampp\mysql\bin>mysql.exe -uroot bak_test -e "show tables " -X comment user 14,--prompt的用法 [root@BlackGhost zhangy]# mysql -u root --prompt=\^\_\^ ^_^show databases; +--------------------+ | Database | +--------------------+ | information_schema | | biztojie | mysql的提示符,我把它设置成笑脸了。 15,-S的用法 [root@BlackGhost zhangy]# mysql -u root -D test -S /tmp/mysql.sock 当我们一台服务器启动了二个不同mysql版本的时候,存放socket的文件是不能一样的,-S用来指定连接到那个 16,-v的用法 [root@BlackGhost zhangy]# mysql -u root -D test -e "show tables;" -v -------------- show tables -------------- 内容不止这么点,只说重点 17,-P的用法 [root@BlackGhost zhangy]# mysql -u root -o test -P 13306 -S /tmp/mysql.sock ############################################################################## mysql导入数据load data infile用法 MySQL高效导入数据的方法,load data infile; 基本语法:   load data [low_priority] [local] infile 'file_name txt' [replace | ignore]   into table tbl_name   fields   [terminated by't']   [OPTIONALLY] enclosed by '']   [escaped by'\' ]]   [lines terminated by'n']   [ignore number lines]   [(col_name, )] load data infile语句从一个文本文件中以很高的速度读入一个表中。使用这个命令之前,mysqld进程(服务)必须已经在运行。由于安全原因,当读取位于服务器上的文件时,文件必须处于数据库目录或可被所有人读取。另外,为了对服务器上文件使用load data infile,在服务器主机上必须有file的权限。 1、如果你指定关键词low_priority,那么MySQL将会等到没有其他人读这个表的时候,才把数据插入。可以使用如下的命令:   load data low_priority infile "/home/mark/data sql" into table Orders; 2、如果指定local关键词,则表明从客户主机读文件。如果local没指定,文件必须位于服务器上。 3、replace和ignore关键词控制对现有的唯一键记录的重复的处理。如果你指定replace,新行将代替有相同的唯一键值的现有行。如果你指定ignore,跳过有唯一键的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复键时,出现一个错误,并且文本文件的余下部分被忽略。例如:   load data low_priority infile "/home/mark/data sql" replace into table Orders; 4、分隔符 (1) fields关键字指定了文件字段的分割格式,如果用到这个关键字,MySQL剖析器希望看到至少有下面的一个选项:     terminated by分隔符:意思是以什么字符作为分隔符     enclosed by字段括起字符     escaped by转义字符     terminated by描述字段的分隔符,默认情况下是tab字符(\t)     enclosed by描述的是字段的括起字符。     escaped by描述的转义字符。默认的是反斜杠(backslash:\ )    例如:load data infile "/home/mark/Orders txt" replace into table Orders fields terminated by',' enclosed by '"'; (2)lines 关键字指定了每条记录的分隔符默认为'\n'即为换行符   如果两个字段都指定了,那fields必须在lines之前。如果不指定fields关键字,缺省值与这样写相同: fields terminated by'\t' enclosed by ’ '' ‘ escaped by'\\'   如果你不指定一个lines子句,缺省值与这样写的相同: lines terminated by'\n'   例如:load data infile "/jiaoben/load.txt" replace into table test fields terminated by ',' lines terminated by '/n'; 5、 load data infile 可以按指定的列把文件导入到数据库中。 当我们要把数据的一部分内容导入的时候,,需要加入一些栏目(列/字段/field)到MySQL数据库中,以适应一些额外的需要。比如,我们要从Access数据库升级到MySQL数据库的时候, 下面的例子显示了如何向指定的栏目(field)中导入数据:   load data infile "/home/Order txt" into table Orders(Order_Number, Order_Date, Customer_ID); 6、当在服务器主机上寻找文件时,服务器使用下列规则: (1)如果给出一个绝对路径名,服务器使用该路径名。 (2)如果给出一个有一个或多个前置部件的相对路径名,服务器相对服务器的数据目录搜索文件。 (3)如果给出一个没有前置部件的一个文件名,服务器在当前数据库的数据库目录寻找文件。 例如: /myfile txt”给出的文件是从服务器的数据目录读取,而作为“myfile txt”给出的一个文件是从当前数据库的数据库目录下读取。 注意:字段中的空值用\N表示 LOAD DATA INFILE 一直被认为是MySQL很强大的一个数据导入工具,因为他速度非常的快。 不过有几个问题一定要注意: 1、编码。 2、灵活导入导出。 举两个例子说明一下: 一、关于编码 我们的示例文本文件: "我爱你","20","相貌平常,经常耍流氓!哈哈" "李奎","21","相貌平常,经常耍流氓!哈哈" "王二米","20","相貌平常,经常耍流氓!哈哈" "老三","24","很强" "老四","34","XXXXX" "老五","52","***%*¥*¥*¥*¥" "小猫","45","中间省略。。。" "小狗","12","就会叫" "小妹","21","PP的很" "小坏蛋","52","表里不一" "上帝他爷","96","非常英俊" "MM来了","10","。。。" "歌颂党","20","社会主义好" "人民好","20","的确是好" "老高","10","学习很好" "斜三","60","眼睛斜了" "中华之子","100","威武的不行了" "大米","63","我爱吃" "苹果","15","好吃" 我们的示例表结构: +-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | Table | Create Table | +-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | t0 | CREATE TABLE `t0` ( `id` bigint(20) unsigned NOT NULL auto_increment, `name` char(20) NOT NULL, `age` tinyint(3) unsigned NOT NULL, `description` text NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `idx_name` (`name`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 | +-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) 我们把这个文本文件从WINDOWS 下COPY到LINUX下看看 mysql> load data infile '/tmp/t0.txt' ignore into table t0 character set gbk fields terminated by ',' enclosed by '"' lines terminated by '\n' (`name`,`age`,`description`); Query OK, 19 rows affected (0.01 sec) Records: 19 Deleted: 0 Skipped: 0 Warnings: 0 mysql> select * from t0; +----+----------+-----+----------------------------+ | id | name | age | description | +----+----------+-----+----------------------------+ | 1 | 我爱你 | 20 | 相貌平常,经常耍流氓!哈哈 | | 2 | 李奎 | 21 | 相貌平常,经常耍流氓!哈哈 | | 3 | 王二米 | 20 | 相貌平常,经常耍流氓!哈哈 | | 4 | 老三 | 24 | 很强 | | 5 | 老四 | 34 | XXXXX | | 6 | 老五 | 52 | ***%*¥*¥*¥*¥ | | 7 | 小猫 | 45 | 中间省略。。。 | | 8 | 小狗 | 12 | 就会叫 | | 9 | 小妹 | 21 | PP的很 | | 10 | 小坏蛋 | 52 | 表里不一 | | 11 | 上帝他爷 | 96 | 非常英俊 | | 12 | MM来了 | 10 | 。。。 | | 13 | 歌颂党 | 20 | 社会主义好 | | 14 | 人民好 | 20 | 的确是好 | | 15 | 老高 | 10 | 学习很好 | | 16 | 斜三 | 60 | 眼睛斜了 | | 17 | 中华之子 | 100 | 威武的不行了 | | 18 | 大米 | 63 | 我爱吃 | | 19 | 苹果 | 15 | 好吃 | +----+----------+-----+----------------------------+ 19 rows in set (0.00 sec) 我来说明一下相关的参数 关于我的导入语句,我现在只说两个,其他的参考手册。 character set gbk; 这个字符集一定要写,要不然就会乱码或者只导入一部分数据。 ignore into table 因为name 列加了唯一索引,加这个是为了避免重复数据插入报错。 加入我们再次运行这个导入语句就会发现 Query OK, 0 rows affected (0.00 sec) Records: 19 Deleted: 0 Skipped: 19 Warnings: 0 没有任何值导入,因为里面已经有了相同的值。 这里也可以用replace into table MySQL会把相同的先干掉,再插入新的值。 mysql> load data infile '/tmp/t0.txt' replace into table t0 character set gbk fields terminated by ',' enclosed by '"' lines terminated by '\n' (`name`,`age`,`description`); Query OK, 38 rows affected (0.00 sec) Records: 19 Deleted: 19 Skipped: 0 Warnings: 0 mysql> select * from t0; +----+----------+-----+----------------------------+ | id | name | age | description | +----+----------+-----+----------------------------+ | 20 | 我爱你 | 20 | 相貌平常,经常耍流氓!哈哈 | | 21 | 李奎 | 21 | 相貌平常,经常耍流氓!哈哈 | | 22 | 王二米 | 20 | 相貌平常,经常耍流氓!哈哈 | | 23 | 老三 | 24 | 很强 | | 24 | 老四 | 34 | XXXXX | | 25 | 老五 | 52 | ***%*¥*¥*¥*¥ | | 26 | 小猫 | 45 | 中间省略。。。 | | 27 | 小狗 | 12 | 就会叫 | | 28 | 小妹 | 21 | PP的很 | | 29 | 小坏蛋 | 52 | 表里不一 | | 30 | 上帝他爷 | 96 | 非常英俊 | | 31 | MM来了 | 10 | 。。。 | | 32 | 歌颂党 | 20 | 社会主义好 | | 33 | 人民好 | 20 | 的确是好 | | 34 | 老高 | 10 | 学习很好 | | 35 | 斜三 | 60 | 眼睛斜了 | | 36 | 中华之子 | 100 | 威武的不行了 | | 37 | 大米 | 63 | 我爱吃 | | 38 | 苹果 | 15 | 好吃 | +----+----------+-----+----------------------------+ 19 rows in set (0.00 sec) (`name`,`age`,`description`); 这些也就是具体的表属性了,指明这个就可以导入想要的数据。 2、关于灵活性,其实也就是一个记录功能 如果想在导入的时候记录一下导入的具体时间怎么办? 我们来看看 先加一个时间属性记录导入时间。 mysql> alter table t0 add update_time timestamp not null; Query OK, 19 rows affected (0.00 sec) Records: 19 Duplicates: 0 Warnings: 0 干掉唯一索引 mysql> alter table t0 drop index idx_name; Query OK, 19 rows affected (0.00 sec) Records: 19 Duplicates: 0 Warnings: 0 mysql> load data infile '/tmp/t0.txt' into table t0 character set gbk fields terminated by ',' enclosed by '"' lines terminated by '\n' (`name`,`age`,`description`) set update_time=current_timestamp; Query OK, 19 rows affected (0.00 sec) Records: 19 Deleted: 0 Skipped: 0 Warnings: 0 mysql> select * from t0; +----+----------+-----+----------------------------+---------------------+ | id | name | age | description | update_time | +----+----------+-----+----------------------------+---------------------+ | 20 | 我爱你 | 20 | 相貌平常,经常耍流氓!哈哈 | 0000-00-00 00:00:00 | ………… | 24 | 老四 | 34 | XXXXX | 0000-00-00 00:00:00 | | 25 | 老五 | 52 | ***%*¥*¥*¥*¥ | 0000-00-00 00:00:00 | ………… | 35 | 斜三 | 60 | 眼睛斜了 | 0000-00-00 00:00:00 | | 36 | 中华之子 | 100 | 威武的不行了 | 0000-00-00 00:00:00 | ………… | 60 | 王二米 | 20 | 相貌平常,经常耍流氓!哈哈 | 2008-06-30 14:58:37 | ………… | 68 | 上帝他爷 | 96 | 非常英俊 | 2008-06-30 14:58:37 | | 69 | MM来了 | 10 | 。。。 | 2008-06-30 14:58:37 | ………… | 75 | 大米 | 63 | 我爱吃 | 2008-06-30 14:58:37 | | 76 | 苹果 | 15 | 好吃 | 2008-06-30 14:58:37 | +----+----------+-----+----------------------------+---------------------+ 38 rows in set (0.00 sec) 新导入的19条记录时间被记录了下来。 只是之前的数据库没有记录,不过现在不需要这些重复数据了。 干掉他就可以了 mysql> alter table t0 order by id desc; Query OK, 38 rows affected (0.01 sec) Records: 38 Duplicates: 0 Warnings: 0 mysql> alter ignore table t0 add unique index idx_name (`name`); Query OK, 38 rows affected (0.00 sec) Records: 38 Duplicates: 19 Warnings: 0 mysql> alter table t0 order by id asc; Query OK, 19 rows affected (0.01 sec) Records: 19 Duplicates: 0 Warnings: 0 mysql> select * from t0; +----+----------+-----+----------------------------+---------------------+ | id | name | age | description | update_time | +----+----------+-----+----------------------------+---------------------+ | 58 | 我爱你 | 20 | 相貌平常,经常耍流氓!哈哈 | 2008-06-30 14:58:37 | | 59 | 李奎 | 21 | 相貌平常,经常耍流氓!哈哈 | 2008-06-30 14:58:37 | | 60 | 王二米 | 20 | 相貌平常,经常耍流氓!哈哈 | 2008-06-30 14:58:37 | | 61 | 老三 | 24 | 很强 | 2008-06-30 14:58:37 | | 62 | 老四 | 34 | XXXXX | 2008-06-30 14:58:37 | | 63 | 老五 | 52 | ***%*¥*¥*¥*¥ | 2008-06-30 14:58:37 | | 64 | 小猫 | 45 | 中间省略。。。 | 2008-06-30 14:58:37 | | 65 | 小狗 | 12 | 就会叫 | 2008-06-30 14:58:37 | | 66 | 小妹 | 21 | PP的很 | 2008-06-30 14:58:37 | | 67 | 小坏蛋 | 52 | 表里不一 | 2008-06-30 14:58:37 | | 68 | 上帝他爷 | 96 | 非常英俊 | 2008-06-30 14:58:37 | | 69 | MM来了 | 10 | 。。。 | 2008-06-30 14:58:37 | | 70 | 歌颂党 | 20 | 社会主义好 | 2008-06-30 14:58:37 | | 71 | 人民好 | 20 | 的确是好 | 2008-06-30 14:58:37 | | 72 | 老高 | 10 | 学习很好 | 2008-06-30 14:58:37 | | 73 | 斜三 | 60 | 眼睛斜了 | 2008-06-30 14:58:37 | | 74 | 中华之子 | 100 | 威武的不行了 | 2008-06-30 14:58:37 | | 75 | 大米 | 63 | 我爱吃 | 2008-06-30 14:58:37 | | 76 | 苹果 | 15 | 好吃 | 2008-06-30 14:58:37 | +----+----------+-----+----------------------------+---------------------+ 19 rows in set (0.00 sec) 现在是达到了目的了,为啥中途要干掉唯一索引呢?因为set 语法 再有IGNORE 的时候会忽略掉。 ############################################################################## mysql中as用法 as 可理解为:用作、当成,作为;一般是重命名列名或者表名。(主要为了查询方便) 1)如:表text, 列 column_1,column_2 你可以写成 select column_1 as 列1,column_2 as 列2 from text as 表; 上面的语句可以解释为:选择 column_1 作为 列1,column_2 作为 列2 从 text 当成 表 2) select * from blog as B; 解析:查找所有blog 表里面的数据,并把blog表格命名为 B; 当你命名一个表之后,你可以在下面用 B 代替 blog; select *from B; 二:as可以作为连接语句的操作符。 sql:create table tablename as select * from tablename2; 解释:上面语句的意思就是先获取到tablename表中的所有记录,之后创建一张tablename表,结构和tablename2表相同,记录为后面语句的查询结果。 ############################# mysql.sock文件的作用 mysql.sock应该mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体,它比tcp快。 Mysql有两种连接方式: (1)TCP/IP (2)socket 对mysql.sock来说,其作用是程序与mysqlserver处于同一台机器,发起本地连接时可用。 例如你无须定义连接host的具体IP得,只要为空或localhost就可以。 在此种情况下,即使你改变mysql的外部port也是一样可能正常连接。 因为你在my.ini中或my.cnf中改变端口后,mysql.sock是随每一次 mysql server启动生成的。已经根据你在更改完my.cnf后重启mysql时重新生成了一次,信息已跟着变更。 那么对于外部连接,必须是要变更port才能连接的。 linux下安装mysql连接的时候经常回提示说找不到mysql.sock文件,解决办法很简单: 如果是新安装的mysql,提示找不到文件,就搜索下,指定正确的位置。 如果mysql.sock文件误删的话,就需要重启mysql服务,如果重启成功的话会在datadir目录下面生成mysql.sock 到时候指定即可。