zoukankan      html  css  js  c++  java
  • cmd命令窗口连接mysql的命令大全

    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 服务器配置变量

  • 相关阅读:
    线性代数思维导图——3.向量
    微分中值定理的基础题型总结
    构造函数
    Python课程笔记(七)
    0241. Different Ways to Add Parentheses (M)
    0014. Longest Common Prefix (E)
    0013. Roman to Integer (E)
    0011. Container With Most Water (M)
    0010. Regular Expression Matching (H)
    0012. Integer to Roman (M)
  • 原文地址:https://www.cnblogs.com/scwbky/p/9811841.html
Copyright © 2011-2022 走看看