mysql中常用命令总结

mysql中常用命令总结

1、mysql -h localhost -u root -p test --------------------------------------------------------------------------- 2

2、mysql -uroot padmin ------------------------------------------------------------------------------------------ 2

3、status ------------------------------------------------------------------------------------------------------------- 2

4、show user() ----------------------------------------------------------------------------------------------------- 2

5、mysql中的时间显示 ----------------------------------------------------------------------------------------- 2

6、mysql中查看数据库信息 ----------------------------------------------------------------------------------- 2

7、查看表信息 ---------------------------------------------------------------------------------------------------- 2

8、create database DBName; ------------------------------------------------------------------------------------ 2

9、drop databse DBName; --------------------------------------------------------------------------------------- 2

10、alter database DBName character set utf8; -------------------------------------------------------------- 2

11、mysql脚本中的注释 --------------------------------------------------------------------------------------- 2

12、创建表 --------------------------------------------------------------------------------------------------------- 3

13、删除表 --------------------------------------------------------------------------------------------------------- 3

14、修改表 (删除列、增加列、修改列、修改表名) --------------------------------------------- 3

15、DML语句(select 、insert、update、delete) ---------------------------------------------------------- 3

16、创建、删除、授权用户 ----------------------------------------------------------------------------------- 4

17、批量执行sql语句------------------------------------------------------------------------------------------- 4 18 、修改mysql用户密码(下面三种方式都通过验证) ------------------------------------------------ 4

19、mysql出现乱码问题解决方案: -------------------------------------------------------------------------- 4

20、mysql自增字段设置 --------------------------------------------------------------------------------------- 5

21、mysql的驱动名称及URL -------------------------------------------------------------------------------- 5

22、mysql常用图形客户端 ------------------------------------------------------------------------------------ 5

1、mysql -h localhost -u root -p test

以root用户登录test@localhost数据库

2、mysql -uroot padmin

以root用户密码admin登录localhost服务器

3、status

查看mysql当前信息

4、show user()

显示当前用户名

5、mysql中的时间显示

select current_time(); --只显示当前时间

select current_date(); --只显示当前日期

select current_timestamp(); --显示当前的时间和日期

6、mysql中查看数据库信息

show databases; --列出所有的数据库模式

select database(); --查看当前使用的数据库模式

use database_schema --切换到指定的数据库模式

7、查看表信息

show tables; --列出当前模式中的数据表

desc tableName; --查看表结构

8、create database DBName;

--创建数据库模式DBName

9、drop databse DBName;

--删除数据库模式DBName

10、alter database DBName character set utf8; --修改数据库DBName的编码方式

11、mysql脚本中的注释

单行注释: --comments

多行注释: /*comments*/

12、创建表

create table if exists tb_test

(

id int primary key auto_increment, --创建int类型的主键,且自增长

name varchar(255) not null, --创建字符类型的列,最大长度为255字节 salary float(11,2), --创建小数类型的列,小数点后两位

birthday date, --创建日期类型的字段,只保存日期

sleep time, --创建时间类型的字段 ,只保存时间

ts timestamp, --创建时间戳类型的列,保存日期和时间

description text, --创建大文本类型数据的列,保存大文本,长度不受限制 picture blob --创建二进制类型的列,保存二进制数据

);

创建临时表 --临时表是指创建后只在当前数据库内有效,断开与数据库的连接后表就自动删除

create temporary table tb_temp

(

id integer,

name varchar(100),

primary key(id)

);

13、删除表

drop table tableName;

14、修改表 (删除列、增加列、修改列、修改表名)

alter table tableName drop name; --删除tableName表中的name列

alter table tableName change name newName dataType; --修改tableName表中的列 alter tableName add name varchar(200) not null default 'helloword'; --向tableName表中添加name列

alter table tableName rename to newTableName ; --修改表名

15、DML语句(select 、insert、update、delete)

select column1,column2…… from tableName; --查询表tableName 中的column1、……数据

select * from tableName; --查询表tableName中的所有字段信息

insert into tableName (column1,column2) values(value1,value2); --向表tableName中插入column1、column2字段数据

update tableName set column1=value1,column2=value2 where conditions; --更新tableName表中符合conditions条件的记录中的column1字段值为value1,column2字段值为value2

delete from tableName where conditions; --删除tableName表中符合条件conditions的记录

delete from tableName; --删除tableName表中的所有记录

16、创建、删除、授权用户

create user username1; --创建用户usernname1

grant all privileges on DBName.* to username1@'% ' identified by 'password123' with grant option;

--授权用户username1仅能访问数据库DBName下的所有数据表,密码为password123

drop user username1; --删除用户username1

17、批量执行sql语句

可以将sql语句写在一个sql格式的脚本文件中,使用批量的方式执行,脚本中的sql语句通过";"分隔,"--"后是注释

使用命令source filename.sql 或反斜杠"\. filename.sql" 在控制台批量执行sql语句 mysql -h myhost -u root -p database < sql.txt (sql.txt中包含sql语句)

18 、修改mysql用户密码(下面三种方式都通过验证)

①在cmd中执行如下命令即可

mysqladmin -uroot -p password '你的新密码'

eg. mysqladmin -u root -p password root --将用户root的密码改为root,最后要求输入原密码。

②在mysql命令行中执行如下语句

mysql> SET PASSWORD FOR root@"%" = PASSWORD('mysql');

③直接在数据库中修改记录

mysql> use mysql

mysql> update user set password = password("new_password") where user = "user_name"; mysql> flush privileges;

19、mysql出现乱码问题解决方案:

(1)修改 my.ini(MySQL Server Instance Configuration 文件)

# CLIENT SECTION

[client]

port=3306

[mysql]

default-character-set=gbk

# SERVER SECTION

[mysqld]

default-character-set=gbk

(2)修改data目录中相应数据库目录下的db.opt配置文件

default-character-set=gbk

default-collation=gbk_chinese_ci

(3)数据库连接串中指定字符集

URL=jdbc:mysql://yourIP/college?user=root&password=yourPassword&useUnicode=true&characterEncoding=gbk 注:在mysql4.1.0版 要加useUnicode=true&characterEncoding=gbk 如果是5.0版以上的,加不加都是没有关系的!(4)在创建数据库时指定字符集

create database yourDB CHARACTER SET gbk;

(5)在dos命令上要设置

set names gbk

在创建数据库是请使用如下语句:

create database dbName character gbk;

20、mysql自增字段设置

alter table album change ALBUM_ID ALBUM_ID bigint not null auto_increment;

alter table album auto_increment=1;

创建:

mysql>create table cc(id int auto_increment,name varchar(20),primary key(id));

修改:

mysql> alter table cc change id id int primary key auto_increment;

注:只有int类型且为primary key 才可以使用auto_increment.

如果用hibernate作为持久层,那么主键ID处用identity类型.

21、mysql的驱动名称及URL

DRIVER: com.mysql.jdbc.Driver

URL: jdbc:mysql://localhost:3306/DBNAME?useUnicode=true&characterEncoding=UTF-8 USERNAME: root

PASSWORD: root

22、mysql常用图形客户端

mysqlfront, mysqlyog, mysqlbrowser, ems mysql manager

 

第二篇:Mysql 基本常用命令

在这篇文章中我们就从连接 MySQL、修改密码、添加用户等方面来学习一些 MySQL 的常用命令。

一、连接MySQL。

格式: mysql -h主机地址 -u用户名 -p用户密码

1、例1:连接到本机上的MYSQL。

首先在打开 DOS 窗口,然后进入目录 mysql\bin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好 MySQL,超级用户 root 是没有密码的,故直接回车即可进入到 MySQL 中了,MySQL 的提示符是:mysql>

2、例2:连接到远程主机上的 MySQL。

假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:

mysql -h110.110.110.110 -uroot -pabcd123

(注:u与root可以不用加空格,其它也一样)

3、退出 MySQL 命令: exit (回车)

二、修改密码。

格式:mysqladmin -u用户名 -p旧密码 password 新密码

1、例1:给root加个密码ab12。首先在DOS下进入目录mysqlbin,然后键入以下命令

mysqladmin -uroot -password ab12

注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。

2、例2:再将root的密码改为djg345。

mysqladmin -uroot -pab12 password djg345

三、添加新用户。

(留心:和上面不同,下面的因为是 MySQL 环境中的命令,所以后面都带一个分号作为命令结束符)

格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"

例1、添加一个用户 test1 密码为 abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以 root 用户连入 MySQL,然后键入以下命令:

grant select, 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页来访问了。

grant select, insert, update,delete on mydb.* to test2@localhost identified by "abc";

如果你不想test2有密码,可以再打一个命令将密码消掉。

grant select, insert, update, delete on mydb.* to test2@localhost identified by "";

在上篇我们讲了登录、添加用户、密码修改等疑问。下篇我们来看看MYSQL中有关数据库方面的操作。留心:你必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下执行 的,而且每个命令以分号结束。

一、操作技巧

1、如果你打命令时,回车后发觉忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK。

2、你可以运用光标上下键调出以前的命令。但以前我用过的一个MYSQL旧版本不支持。我现在用的是

mysql-3.23.27-beta-win。

二、显示命令

1、显示数据库列表。

show databases;

刚开始时才两个数据库:mysql 和 test。mysql 库很主要它里面有 MySQL 的系统信息,我们改密码和新增用户,实际上就是用这个库执行 操作。

2、显示库中的数据表:

use mysql; //打开库,学过 FOXBASE 的一定不会陌生吧

show tables;

3、显示数据表的结构:

describe 表名;

4、建库:

create database 库名;

5、建表:

use 库名;

create table 表名 (字段设定列表);

6、删库和删表:

drop database 库名;

drop table 表名;

7、将表中记录清空:

delete from 表名;

8、显示表中的记录:

select * from 表名;

三、一个建库和建表以及插入数据的实例

drop database if exists school; //如果存在SCHOOL则删除 create database school; //建立库SCHOOL

use school; //打开库SCHOOL

create table teacher //建立表TEACHER

(

id int(3) auto_increment not null primary key,

name char(10) not null,

address varchar(50) default '深圳',

year date

); //建表结束

//以下为插入字段

insert into teacher values('','glchengang','深圳一中','1976-10-10'); insert into teacher values('','jack','深圳一中','1975-12-23');

注:在建表中(1)将 ID 设为长度为 3 的数字字段 int(3) 并让它每个记录自动加一,auto_increment 并不能为空 not null 而且让他成为主字段 primary key(2)将 NAME 设为长度为 10 的字符字段(3)将 ADDRESS 设为长度 50 的字符字段,而且缺省值为深圳。varchar 和char 有什么区别呢,只有等以后的文章再说了。(4)将 YEAR 设为日期字段。

如果你在 MySQL 提示符键入上面的命令也可以,但不方便调试。你可以将以上命令原样写入一个文本文件中假设为 school.sql,然后复制到 c:\ 下,并在 DOS 状态进入目录 \mysql\bin\ ,然后键入以下命令:

mysql -uroot -p密码 < c:\school.sql

如果成功,空出一行无任何显示;如有不正确,会有提示。(以上命令已经调试,你只要将//的注释去掉即可运用)。

四、将文本数据转到数据库中

1、文本数据应符合的格式:字段数据之间用 tab 键隔开,null 值用 \n 来代替.

例:

3 rose 深圳二中 1976-10-10

4 mike 深圳一中 1975-12-23

2、数据传入命令

load data local infile "文件名" into table 表名;

留心:你最好将文件复制到 \mysql\bin 目录下,并且要先用 use 命令打表所在的库。

五、备份数据库: (命令在DOS的 \mysql\bin 目录下执行)

mysqldump --opt school>school.bbb

注释:将数据库 school 备份到 school.bbb 文件,school.bbb 是一个文本文件,文件名任取,打开看看你会有新发觉。

--------------------------------------------------------------------

数据库备份操作:

MySQL有很多可以导入数据的要领,然而这些只是数据传输中的一半,另外的一般是从MySQL数据库中导出数据。有许多的原由我们须要导出数据。一个主要的原由是用于备份数据库。数据的造价常常是昂贵的,须要谨慎处理它们。经常地备份可以帮助防止 宝贵数据地丢失;另外一个原由是,也许您希望导出数据来共享。 在这个信息技能不断成长的世界中,共享数据变得越来越多见。

比方说Macmillan USA维护护着一个将要出版的书籍的大型数据库。这个数据库在许多书店之间共享,这样他们就知道哪些书将会很快出版。医院越来越走向采用无纸病历记录,这样这些病历可以随时跟着你。世界变得越来越小,信息也被共享得越来越多。有很多中导出数据得要领,它们都跟导入数据很相似。因为,毕竟,这些都只是一种透视得形式。从数据库导出的数据就是从另一端导入的数据。这里我们并不讨论其他的数据库各种各样的导出数据的要领,您将学会如何 用MySQL来实现数据导出。

运用 mysqldump:

(mysqldump命令位于mysql/bin/目录中)

mysqldump工具很多方面类似相反作用的工具mysqlimport。它们有一些同样的选项。但mysqldump能够做更多的事情。它可以把整个数据库装载到一个单独的文本文件中。这个文件包含有所有重建您的数据库所须要的SQL命令。这个命令取得所有的模式(Schema,后面有解释)并且将其转换成DDL语法(create语句,即数据库解释语句),取得所有的数据,并且从这些数据中建立 insert语句。这个工具将您的数据库中所有的设计倒转。因为所有的东西都被包含到了一个文本文件中。这个文本文件可以用一个基本的批处理和一个合适SQL语句导回到MySQL中。这个工具令人难以置信地基本而高速。决不会有半点让人头疼地地点。

因此,如果您像装载整个数据库Meet_A_Geek的内容到一个文件中,可以运用下面的命令:

bin/mysqldump –p Meet_A_Geek > MeetAGeek_Dump_File.txt

这个语句也允许您指定一个表执行 dump(备份/导出/装载?)。如果您只是希望把数据库Meet_A_Geek中的表Orders中的整个内容导出到一个文件,可以运用下面的命令:

bin/mysqldump –p Meet_A_Geek Orders >MeetAGeek_Orders.txt

这个非常的灵活,您甚至可以运用 where从句来选择您须要的记录导出到文件中。要达到这样的目的,可以运用类似于下面的命令:

bin/mysqldump –p –where="Order_ID > 2000" Meet_A_Geek Orders > Special_Dump.txt

mysqldump工具有大量的选项,部分选项如下表:

选项/Option 作用/Action Performed

--add-drop-table

这个选项将会在每一个表的前面加上drop TABLE IF EXISTS语句,这样可以保证导回MySQL数据库的时候不会出错,因为每次导回的时候,都会首先检查表能不能存在,存在就删除

--add-locks

这个选项会在insert语句中捆上一个LOCK TABLE和UNLOCK TABLE语句。这就防止 在这些记录被再次导入数据库时其他用户对表执行 的操作-c or - complete_insert

这个选项使得mysqldump命令给每一个产生insert语句加上列(field)的名字。当把数据导出导另外一个数据库时这个选项很有用。

--delayed-insert 在insert命令中加入DELAY选项

-F or -flush-logs 运用这个选项,在执行导出之前将会刷新MySQL服务器的log.

-f or -force 运用这个选项,即使有不正确发生,仍然继续导出

--full 这个选项把附加信息也加到create TABLE的语句中

-l or -lock-tables 运用这个选项,导出表的时候服务器将会给表加锁。

-t or -no-create- info

这个选项使的mysqldump命令不建立 create TABLE语句,这个选项在您只须要数据而不须要 DDL(数据库解释语句)时很方便。

-d or -no-data 这个选项使的mysqldump命令不建立 insert语句。

在您只须要 DDL语句时,可以运用这个选项。

--opt 此选项将打开所有会提高文件导出速度和创造一个可以更快导入的文件的选项。

-q or -quick 这个选项使得MySQL不会把整个导出的内容读入内存再执行导出,而是在读到的时候就写入导文件中。

-T path or -tab = path 这个选项将会建立两个文件,一个文件包含DDL语句或者表建立语句,另一个文件包含数据。DDL文件被命名为table_name.sql,数据文件被命名为table_name.txt.路径名是存放这两个文件的目录。目录必须已经存在,并且命令的运用者有对文件的特权。

-w "where Clause" or -where = "where clause "

如前面所讲的,您可以运用这一选项来过筛选将要放到 导出文件的数据。

假定您须要为一个表单中要用到的帐号建立一个文件,经理要看今年(20xx年)所有的订单(Orders),它们并不对DDL感兴趣,并且须要文件有逗号分隔,因为这样就很容易导入到Excel中。 为了完成这个人物,您可以运用下面的句子:

bin/mysqldump –p –where "Order_Date >='2000-01-01'"

–tab = /home/mark –no-create-info –fields-terminated-by=, Meet_A_Geek Orders

这将会得到您想要的结果。

schema:模式

The set of statements, exp ressed in data definition language, that completely describe the structure of a data base.

一组以数据解释语言来表达的语句集,该语句集完整地描述了数据库的结构。

select INTO OUTFILE :

如果您觉得mysqldump工具不够酷,就运用 select INTO OUTFILE吧, MySQL同样提供一个跟LOAD DATA INFILE命令有相反作用的命令,这就是select INTO OUTFILE 命令,这两个命令有很多的相似之处。首先,它们有所有的选项几乎相同。现在您须要完成前面用mysqldump完成的功能,可以依照下面的步骤执行 操作:

1. 确保mysqld进程(服务)已经在运行

2. cd /usr/local/mysql

3. bin/mysqladmin ping ;// 如果这个句子通不过,可以用这个:mysqladmin -u root -p ping

mysqladmin ping用于检测mysqld的状态,is alive说明正在运行,出错则可能须要用户名和密码。

4. 启动MySQL 监听程序.

5. bin/mysql –p Meet_A_Geek;// 进入mysql命令行,并且打开数据库Meet_A_Geek,须要输入密码

6. 在命令行中,输入一下命令:

select * INTO OUTFILE '/home/mark/Orders.txt'

FIELDS

TERMINATED BY = ','

FROM Orders

where Order_Date >= '2000-01-01'

在你按了Return(回车)之后,文件就建立了。这个句子就像一个准则的select语句,只是把想屏幕的输出重定向到了文件中。这意味这您可以运用 join来实现多表的高级查询。这个特点也可以被用作一个报表产生器。

比方说,您可以组合这一章中讨论的要领来产生一个非常有趣的查询,试试这个:

在mysql目录建立一个名为Report_G.rpt 的文本文件,加入下面的行:

USE Meet_A_Geek;

insert INTO Customers (Customer_ID, Last_Name, First_Name)

VALUES (NULL, "Kinnard", "Vicky");

insert INTO Customers (Customer_ID, Last_Name, First_Name)

VALUES (NULL, "Kinnard", "Steven");

insert INTO Customers (Customer_ID, Last_Name, First_Name)

VALUES (NULL, "Brown", "Sam");

select Last_Name INTO OUTFILE '/home/mark/Report.rpt'

FROM Customers where Customer_ID > 1;

然后确认 mysql进程在运行,并且您在mysql目录中, 输入下面的命令:

bin/mysql < Report_G.rpt检查您命名作为输出的文件,这个文件将会包含所有您在Customers表中输入的顾客的姓。 如您所见,您可以运用今天学到的导入/导出(import/exp ort)的要领来帮助得到报表

相关推荐