cmd命令窗口连接mysql的命令大全
连接:mysql -h主机地址 -u用户名 -p用户密码 (注:u与root可以不用加空格,其它也一样)
断开:exit (回车)
创建授权:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
修改密码:set password for 's6mism'@localhost= password('s6mism');
删除授权: revoke select,insert,update,delete om *.* fromtest2@localhost;
显示数据库:show databases;
显示数据表:show tables;
显示表结构:describe 表名;
创建库:create database 库名;
删除库:drop database 库名;
使用库:use 库名;
创建表:create table 表名 (字段设定列表);
删除表:drop table 表名;
修改表:alter table t1 rename t2
查询表:select * from 表名;
清空表:delete from 表名;
备份表: K:mysqlmysql-5.5.28-winx64in>mysqldump -uroot -proot --databases test odrm >d:odrm.sql;;
恢复表: mysqlbinmysql -h(ip) -uroot -p(password) databasenametablename < tablename.sql(操作前先把原来表删除)
增加列:ALTER TABLE t2 ADD c INT UNSIGNED NOT NULL AUTO_INCREMENT,ADDINDEX (c);
修改列:ALTER TABLE t2 MODIFY a TINYINT NOT NULL, CHANGE b cCHAR(20);
删除列:ALTER TABLE t2 DROP COLUMN c;
备份数据库:mysqlinmysqldump -h(ip) -uroot -p(password) databasename> database.sql
恢复数据库:mysqlinmysql -h(ip) -uroot -p(password) databasename< database.sql
复制数据库:mysqlinmysqldump --all-databases >all-databases.sql
修复数据库:mysqlcheck -A -o -uroot -p54safer
文本数据导入: load data local infile "文件名" into table 表名;
数据导入导出:mysqlinmysqlimport database tables.txt
第一招、mysql服务的启动和停止
net stop mysql
net start mysql
第二招、登陆mysql
语法如下: mysql -u用户名-p用户密码
键入命令mysql -uroot -p,回车后提示你输入密码,输入12345,然后回车即可进入到mysql中了,mysql的提示符是:
mysql>
注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP
第三招、增加新用户
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"
如,增加一个用户user1密码为password1,让其可以在本机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:
grant select,insert,update,delete on *.* touser1@localhost Identified by "password1";
如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。
如果你不想user1有密码,可以再打一个命令将密码去掉。
grant select,insert,update,delete on mydb.* touser1@localhost identified by"";
第四招: 操作数据库
登录到mysql中,然后在mysql的提示符下运行下列命令,每个命令以分号结束。
1、 显示数据库列表。
show databases;
缺省有两个数据库:mysql和test。mysql库存放着mysql的系统和用户权限信息,我们改密码和新增用户,实际上就是对这个库进行操作。
2、 显示库中的数据表:
use mysql;
show tables;
3、 显示数据表的结构:
describe 表名;
4、 建库与删库:
create database 库名;
drop database 库名;
5、 建表:
use 库名;
create table 表名(字段列表);
drop table 表名;
6、 清空表中记录:
delete from 表名;
7、 显示表中的记录:
select * from 表名;
第五招、导出和导入数据
1. 导出数据:
mysqldump --opt test > mysql.test
即将数据库test数据库导出到mysql.test文件,后者是一个文本文件
如:mysqldump -u root -p123456 --databases dbname >mysql.dbname
就是把数据库dbname导出到文件mysql.dbname中。
参数说明:
--all-databases , -A
导出全部数据库。
mysqldump -uroot -p
--all-databases
--all-tablespaces , -Y
导出全部表空间。
mysqldump -uroot -p
--all-databases --all-tablespaces
--no-tablespaces , -y
不导出任何表空间信息。
mysqldump -uroot -p
--all-databases --no-tablespaces
--add-drop-database
每个数据库创建之前添加
drop
数据库语句。
mysqldump -uroot -p
--all-databases --add-drop-database
--add-drop-table
每个数据表创建之前添加
drop
数据表语句。(默认为打开状态,使用
--skip-add-drop-table取消选项)
mysqldump -uroot -p
--all-databases (默认添加drop语句)
mysqldump -uroot -p
--all-databases –skip-add-drop-table (取消drop语句)
--add-locks
在每个表导出之前增加LOCK TABLES并且之后UNLOCK
TABLE
。(默认为打开状态,使用
--skip-add-locks取消选项)
mysqldump -uroot -p
--all-databases (默认添加LOCK语句)
mysqldump -uroot -p
--all-databases –skip-add-locks (取消LOCK语句)
--allow-keywords
允许创建是关键词的列名字。这由表名前缀于每个列名做到。
mysqldump -uroot -p
--all-databases --allow-keywords
--apply-slave-statements
在
'CHANGE MASTER'
前添加
'STOP SLAVE'
,并且在导出的最后添加
'START SLAVE'
。
mysqldump -uroot -p
--all-databases --apply-slave-statements
--character-sets-dir
字符集文件的目录
mysqldump -uroot -p
--all-databases --character-sets-dir=/usr/local/mysql/share/mysql/charsets
--comments
附加注释信息。默认为打开,可以用
--skip-comments取消
mysqldump -uroot -p
--all-databases (默认记录注释)
mysqldump -uroot -p
--all-databases --skip-comments (取消注释)
--compatible
导出的数据将和其它数据库或旧版本的MySQL 相兼容。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options等,
要使用几个值,用逗号将它们隔开。它并不保证能完全兼容,而是尽量兼容。
mysqldump -uroot -p
--all-databases --compatible=ansi
--compact
导出更少的输出信息(用于调试)。去掉注释和头尾等结构。可以使用选项:
--skip-add-drop-table --skip-add-locks --skip-comments --skip-disable-keys
mysqldump -uroot -p
--all-databases --compact
--complete-insert, -c
使用完整的
insert
语句(包含列名称)。这么做能提高插入效率,但是可能会受到max_allowed_packet参数的影响而导致插入失败。
mysqldump -uroot -p
--all-databases --complete-insert
--compress, -C
在客户端和服务器之间启用压缩传递所有信息
mysqldump -uroot -p
--all-databases --compress
--create-options, -a
在
CREATE
TABLE
语句中包括所有MySQL特性选项。(默认为打开状态)
mysqldump -uroot -p
--all-databases
--databases, -B
导出几个数据库。参数后面所有名字参量都被看作数据库名。
mysqldump -uroot -p
--databases test mysql
--debug
输出debug信息,用于调试。默认值为:d:t,/tmp/mysqldump.trace
mysqldump -uroot -p
--all-databases --debug
mysqldump -uroot -p
--all-databases --debug=” d:t,/tmp/debug.trace”
--debug-check
检查内存和打开文件使用说明并退出。
mysqldump -uroot -p
--all-databases --debug-check
--debug-info
输出调试信息并退出
mysqldump -uroot -p
--all-databases --debug-info
--default-character-set
设置默认字符集,默认值为utf8
mysqldump -uroot -p
--all-databases --default-character-set=utf8
--delayed-insert
采用延时插入方式(
INSERT
DELAYED)导出数据
mysqldump -uroot -p
--all-databases --delayed-insert
--delete-master-logs
master备份后删除日志. 这个参数将自动激活
--master-data。
mysqldump -uroot -p
--all-databases --delete-master-logs
--disable-keys
对于每个表,用/*!40000
ALTER
TABLE
tbl_name DISABLE KEYS */;和/*!40000
ALTER
TABLE
tbl_name ENABLE KEYS */;语句引用
INSERT
语句。这样可以更快地导入dump出来的文件,因为它是在插入所有行后创建索引的。该选项只适合MyISAM表,默认为打开状态。
mysqldump -uroot -p
--all-databases
--dump-slave
该选项将主的binlog位置和文件名追加到导出数据的文件中(show slave status)。设置为1时,将会以CHANGE MASTER命令输出到数据文件;设置为2时,会在change前加上注释。该选项将会打开
--lock-all-tables,除非--single-transaction被指定。该选项会自动关闭--lock-tables选项。默认值为0。
mysqldump -uroot -p
--all-databases --dump-slave=1
mysqldump -uroot -p
--all-databases --dump-slave=2 --master-data
该选项将当前服务器的binlog的位置和文件名追加到输出文件中(show master status)。如果为1,将会输出CHANGE MASTER 命令;如果为2,输出的CHANGE MASTER命令前添加注释信息。该选项将打开
--lock-all-tables 选项,除非--single-transaction也被指定(在这种情况下,全局读锁在开始导出时获得很短的时间;其他内容参考下面的--single-transaction选项)。该选项自动关闭--lock-tables选项。
mysqldump -uroot -p
--host=localhost --all-databases --master-data=1;
mysqldump -uroot -p
--host=localhost --all-databases --master-data=2; --events, -E
导出事件。
mysqldump -uroot -p
--all-databases --events
--extended-insert, -e
使用具有多个
VALUES
列的
INSERT
语法。这样使导出文件更小,并加速导入时的速度。默认为打开状态,使用
--skip-extended-insert取消选项。
mysqldump -uroot -p
--all-databases
mysqldump -uroot -p
--all-databases--skip-extended-insert (取消选项)
--fields-terminated-by
导出文件中忽略给定字段。与
--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test
--tab=”/home/mysql” --fields-terminated-by=”#”
--fields-enclosed-by
输出文件中的各个字段用给定字符包裹。与
--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test
--tab=”/home/mysql” --fields-enclosed-by=”#”
--fields-optionally-enclosed-by
输出文件中的各个字段用给定字符选择性包裹。与
--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p test test
--tab=”/home/mysql” --fields-enclosed-by=”#” --fields-optionally-enclosed-by =”#”
--fields-escaped-by
输出文件中的各个字段忽略给定字符。与
--tab选项一起使用,不能用于--databases和--all-databases选项
mysqldump -uroot -p mysql
user
--tab=”/home/mysql” --fields-escaped-by=”#”
--flush-logs
开始导出之前刷新日志。
请注意:假如一次导出多个数据库(使用选项
--databases或者--all-databases),将会逐个数据库刷新日志。除使用--lock-all-tables或者--master-data外。在这种情况下,日志将会被刷新一次,相应的所以表同时被锁定。因此,如果打算同时导出和刷新日志应该使用--lock-all-tables 或者--master-data 和--flush-logs。
mysqldump -uroot -p
--all-databases --flush-logs
--flush-privileges
在导出mysql数据库之后,发出一条FLUSH
PRIVILEGES
语句。为了正确恢复,该选项应该用于导出mysql数据库和依赖mysql数据库数据的任何时候。
mysqldump -uroot -p
--all-databases --flush-privileges
--force
在导出过程中忽略出现的SQL错误。
mysqldump -uroot -p
--all-databases --force
--help
显示帮助信息并退出。
mysqldump
--help
--hex-blob
使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用该选项。影响到的字段类型有
BINARY
、VARBINARY、BLOB。
mysqldump -uroot -p
--all-databases --hex-blob
--host, -h
需要导出的主机信息
mysqldump -uroot -p
--host=localhost --all-databases
--ignore-table
不导出指定表。指定忽略多个表时,需要重复多次,每次一个表。每个表必须同时指定数据库和表名。例如:
--ignore-table=database.table1 --ignore-table=database.table2 ……
mysqldump -uroot -p
--host=localhost --all-databases --ignore-table=mysql.user
--include-master-host-port
在
--dump-slave产生的'CHANGE MASTER TO..'语句中增加'MASTER_HOST=<host>,MASTER_PORT=<port>'
mysqldump -uroot -p
--host=localhost --all-databases --include-master-host-port
--insert-ignore
在插入行时使用
INSERT
IGNORE
语句.
mysqldump -uroot -p
--host=localhost --all-databases --insert-ignore
--lines-terminated-by
输出文件的每行用给定字符串划分。与
--tab选项一起使用,不能用于--databases和--all-databases选项。
mysqldump -uroot -p
--host=localhost test test --tab=”/tmp/mysql” --lines-terminated-by=”##”
--lock-all-tables, -x
提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭
--single-transaction 和--lock-tables 选项。
mysqldump -uroot -p
--host=localhost --all-databases --lock-all-tables
--lock-tables, -l
开始导出前,锁定所有表。用
READ
LOCAL
锁定表以允许MyISAM表并行插入。对于支持事务的表例如InnoDB和BDB,
--single-transaction是一个更好的选择,因为它根本不需要锁定表。
请注意当导出多个数据库时,
--lock-tables分别为每个数据库锁定表。因此,该选项不能保证导出文件中的表在数据库之间的逻辑一致性。不同数据库表的导出状态可以完全不同。
mysqldump -uroot -p
--host=localhost --all-databases --lock-tables
--log-error
附加警告和错误信息到给定文件
mysqldump -uroot -p
--host=localhost --all-databases --log-error=/tmp/mysqldump_error_log.err
--max_allowed_packet
服务器发送和接受的最大包长度。
mysqldump -uroot -p
--host=localhost --all-databases --max_allowed_packet=10240
--net_buffer_length
TCP/IP和socket连接的缓存大小。
mysqldump -uroot -p
--host=localhost --all-databases --net_buffer_length=1024
--no-autocommit
使用autocommit/
commit
语句包裹表。
mysqldump -uroot -p
--host=localhost --all-databases --no-autocommit
--no-create-db, -n
只导出数据,而不添加
CREATE
DATABASE
语句。
mysqldump -uroot -p
--host=localhost --all-databases --no-create-db
--no-create-info, -t
只导出数据,而不添加
CREATE
TABLE
语句。
mysqldump -uroot -p
--host=localhost --all-databases --no-create-info
--no-data, -d
不导出任何数据,只导出数据库表结构。
mysqldump -uroot -p
--host=localhost --all-databases --no-data
--no-set-names, -N
等同于
--skip-set-charset
mysqldump -uroot -p
--host=localhost --all-databases --no-set-names
--opt
等同于
--add-drop-table, --add-locks, --create-options, --quick, --extended-insert, --lock-tables, --set-charset, --disable-keys 该选项默认开启, 可以用--skip-opt禁用.
mysqldump -uroot -p
--host=localhost --all-databases --opt
--order-by-primary
如果存在主键,或者第一个唯一键,对每个表的记录进行排序。在导出MyISAM表到InnoDB表时有效,但会使得导出工作花费很长时间。
mysqldump -uroot -p
--host=localhost --all-databases --order-by-primary
--password, -p
连接数据库密码
--pipe(windows系统可用)
使用命名管道连接mysql
mysqldump -uroot -p
--host=localhost --all-databases --pipe
--port, -P
连接数据库端口号
--protocol
使用的连接协议,包括:tcp, socket, pipe, memory.
mysqldump -uroot -p
--host=localhost --all-databases --protocol=tcp
--quick, -q
不缓冲查询,直接导出到标准输出。默认为打开状态,使用
--skip-quick取消该选项。
mysqldump -uroot -p
--host=localhost --all-databases
mysqldump -uroot -p
--host=localhost --all-databases --skip-quick
--quote-names,-Q
使用(`)引起表和列名。默认为打开状态,使用
--skip-quote-names取消该选项。
mysqldump -uroot -p
--host=localhost --all-databases
mysqldump -uroot -p
--host=localhost --all-databases --skip-quote-names
--replace
使用
REPLACE
INTO
取代
INSERT
INTO
.
mysqldump -uroot -p
--host=localhost --all-databases --replace
--result-file, -r
直接输出到指定文件中。该选项应该用在使用回车换行对(\r\n)换行的系统上(例如:DOS,Windows)。该选项确保只有一行被使用。
mysqldump -uroot -p
--host=localhost --all-databases --result-file=/tmp/mysqldump_result_file.txt
--routines, -R
导出存储过程以及自定义函数。
mysqldump -uroot -p
--host=localhost --all-databases --routines
--set-charset
添加
'SET NAMES default_character_set'
到输出文件。默认为打开状态,使用
--skip-set-charset关闭选项。
mysqldump -uroot -p
--host=localhost --all-databases
mysqldump -uroot -p
--host=localhost --all-databases --skip-set-charset
--single-transaction
该选项在导出数据之前提交一个
BEGIN
SQL语句,
BEGIN
不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎,仅InnoDB。本选项和
--lock-tables 选项是互斥的,因为LOCK TABLES 会使任何挂起的事务隐含提交。要想导出大表的话,应结合使用--quick 选项。
mysqldump -uroot -p
--host=localhost --all-databases --single-transaction
--dump-date
将导出时间添加到输出文件中。默认为打开状态,使用
--skip-dump-date关闭选项。
mysqldump -uroot -p
--host=localhost --all-databases
mysqldump -uroot -p
--host=localhost --all-databases --skip-dump-date
--skip-opt
禁用–opt选项.
mysqldump -uroot -p
--host=localhost --all-databases --skip-opt
--socket,-S
指定连接mysql的socket文件位置,默认路径/tmp/mysql.sock
mysqldump -uroot -p
--host=localhost --all-databases --socket=/tmp/mysqld.sock
--tab,-T
为每个表在给定路径创建tab分割的文本文件。注意:仅仅用于mysqldump和mysqld服务器运行在相同机器上。
mysqldump -uroot -p
--host=localhost test test --tab="/home/mysql"
--tables
覆盖
--databases (-B)参数,指定需要导出的表名。
mysqldump -uroot -p
--host=localhost --databases test --tables test
--triggers
导出触发器。该选项默认启用,用
--skip-triggers禁用它。
mysqldump -uroot -p
--host=localhost --all-databases --triggers
--tz-utc
在导出顶部设置时区TIME_ZONE=
'+00:00'
,以保证在不同时区导出的
TIMESTAMP
数据或者数据被移动其他时区时的正确性。
mysqldump -uroot -p
--host=localhost --all-databases --tz-utc
--user, -u
指定连接的用户名。
--verbose, --v
输出多种平台信息。
--version, -V
输出mysqldump版本信息并退出
--where, -w
只转储给定的
WHERE
条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。
mysqldump -uroot -p
--host=localhost --all-databases --where=” user='root'”
--xml, -X
导出XML格式.
mysqldump -uroot -p
--host=localhost --all-databases --xml
--plugin_dir
客户端插件的目录,用于兼容不同的插件版本。
mysqldump -uroot -p
--host=localhost --all-databases --plugin_dir=”/usr/local/lib/plugin”
--default_auth
客户端插件默认使用权限。
mysqldump -uroot -p
--host=localhost --all-databases --default-auth=”/usr/local/
2. 导入数据:
mysqlimport -u root -p123456 < mysql.dbname。
不用解释了吧。
3. 将文本数据导入数据库:
文本数据的字段数据之间用tab键隔开。
use test;
load data local infile "文件名" into table 表名;
1:使用SHOW语句找出在服务器上当前存在什么数据库:
mysql> SHOW DATABASES;
2:2、创建一个数据库MYSQLDATA
mysql> CREATE DATABASE MYSQLDATA;
3:选择你所创建的数据库
mysql> USE MYSQLDATA; (按回车键出现Database changed时说明操作成功!)
4:查看现在的数据库中存在什么表
mysql> SHOW TABLES;
5:创建一个数据库表
mysql> CREATE TABLE MYTABLE (name VARCHAR(20), sexCHAR(1));
6:显示表的结构:
mysql> DESCRIBE MYTABLE;
7:往表中加入记录
mysql> insert into MYTABLE values ("hyq","M");
8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTOTABLE MYTABLE;
9:导入.sql文件命令(例如D:/mysql.sql)
mysql>use database;
mysql>source d:/mysql.sql;
10:删除表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>delete from MYTABLE;
12:更新表中数据
mysql>update MYTABLE set sex="f" where name='hyq';13:备份数据库mysqldump -u root库名>xxx.data14:
例2:连接到远程主机上的MYSQL
假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
mysql-h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)
3、退出MYSQL命令:exit
(一) 连接MYSQL:
格式: mysql -h主机地址 -u用户名-p用户密码
1、例1:连接到本机上的MYSQL
首先在打开DOS窗口,然后进入mysql安装目录下的bin目录下,例如: D:mysqlin,再键入命令mysql -uroot-p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是:mysql>
2、例2:连接到远程主机上的MYSQL
假设远程主机的IP为:10.0.0.1,用户名为root,密码为123。则键入以下命令:
mysql -h10.0.0.1 -uroot-p123
(注:u与root可以不用加空格,其它也一样)
3、退出MYSQL命令
exit (回车)
(二) 修改密码:
格式:mysqladmin -u用户名 -p旧密码password 新密码
1、例1:给root加个密码123。首先在DOS下进入目录C:mysqlin,然后键入以下命令:
mysqladmin -uroot -password123
注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2、例2:再将root的密码改为456
mysqladmin -uroot -pab12password 456
(三) 增加新用户:(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
格式:grant select on 数据库.* to用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MYSQL,然后键入以下命令:
grantselect,insert,update,delete on *.* to test1@"%" Identified by"abc";
但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
grantselect,insert,update,delete on mydb.* to test2@localhost identifiedby "abc";
如果你不想test2有密码,可以再打一个命令将密码消掉。
grantselect,insert,update,delete on mydb.* to test2@localhost identifiedby "";
(四) 显示命令
1、显示数据库列表:
show databases;
刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
2、显示库中的数据表:
use mysql; //打开库
show tables;
3、显示数据表的结构:
describe 表名;
4、建库:
create database 库名;
5、建表:
use 库名;
create table 表名(字段设定列表);
6、删库和删表:
drop database 库名;
drop table 表名;
7、将表中记录清空:
delete from 表名;
8、显示表中的记录:
select * from 表名;
MySQL导入导出命令
1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc >wcnc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc users>wcnc_users.sql
3.导出一个数据库结构
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc>d:wcnc_db.sql
-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table
4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:wcnc_db.sql (注:如果写成sourced:wcnc_db.sql,就会报语法
使用load data 批量导入数据,这种做法可以瞬间导入数据,用处非常大!
LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name.txt'
[REPLACE | IGNORE]
INTO TABLE tbl_name
[FIELDS 字段操作,设置每个字段的分隔符
[TERMINATED BY 'string']
[[OPTIONALLY] ENCLOSED BY 'char']
[ESCAPED BY 'char' ]
]
[LINES 行操作,从某一个字符开始,到某个字符
[STARTING BY 'string']
[TERMINATED BY 'string']
]
[IGNORE number LINES] 行操作,忽略某行
[(col_name_or_user_var,...)] 字段操作,写入的字段与数据对应
[SET col_name = expr,...)]
示例:load data infile '/test/test.file' intotable 'test' fields terminated by " " (fieldsOne,fieldsTwo);
意思是, 载入/test/test.file到表test中,使用 分割字段,写入fieldsOne和fieldsTwo中,默认以换行符作为一个行分割!
- 使用 SHOW CREATE TABLE 命令获取创建数据表(CREATE TABLE) 语句,该语句包含了原数据表的结构,索引等。
- 复制以下命令显示的SQL语句,修改数据表名,并执行SQL语句,通过以上命令 将完全的复制数据表结构。
- 如果你想复制表的内容,你就可以使用 INSERT INTO ... SELECT 语句来实现。
SHOW CREATE TABLE odrm ;;
获取服务器元数据
SELECT VERSION( ) 服务器版本信息
SELECT DATABASE( ) 当前数据库名 (或者返回空)
SELECT USER( ) 当前用户名
SHOW STATUS 服务器状态
SHOW VARIABLES 服务器配置变量