mysql 常用命令用法总结脚本之家整理版
网络编程 2021-07-05 15:27www.168986.cn编程入门
在日常工作中,会简单的使用一下mysql,故对常见命令操作一下,常用方式如下
一、启动与退出
1、进入MySQL启动MySQL Command Line Client(MySQL的DOS界面),直接输入安装时的密码即可。此时的提示符是mysql>
2、退出MySQLquit或exit
二、库操作
1、、创建数据库
命令create database <数据库名>
例如建立一个名为xhkdb的数据库
mysql> create database xhkdb;
2、显示所有的数据库
命令show databases (注意有个s)
mysql> show databases;
3、删除数据库
命令drop database <数据库名>
例如删除名为 xhkdb的数据库
mysql> drop database xhkdb;
4、连接数据库
命令 use <数据库名>
例如如果xhkdb数据库存在,尝试存取它
mysql> use xhkdb;
屏幕提示Database changed
5、当前选择(连接)的数据库
mysql> select database();
6、当前数据库包含的表信息
mysql> show tables; (注意有个s)
三、表操作,操作之前应连接某个数据库
1、建表
命令create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
mysql> create table MyClass(
> id int(4) not null primary key auto_increment,
> name char(20) not null,
> sex int(4) not null default '0',
> degree double(16,2));
2、获取表结构
命令 desc 表名,或者show columns from 表名
mysql> desc MyClass;
mysql> show columns from MyClass;
3、删除表
命令drop table <表名>
例如删除表名为 MyClass 的表
mysql> drop table MyClass;
4、插入数据
命令insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]
例如,往表 MyClass中插入二条记录, 这二条记录表示编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5.
mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);
5、查询表中的数据
1)、查询所有行
命令 select <字段1,字段2,...> from < 表名 > where < 表达式 >
例如查看表 MyClass 中所有数据
mysql> select from MyClass;
2)、查询前几行数据
例如查看表 MyClass 中前2行数据
mysql> select from MyClass order by id limit 0,2;
6、删除表中数据
命令delete from 表名 where 表达式
例如删除表 MyClass中编号为1 的记录
mysql> delete from MyClass where id=1;
7、修改表中数据update 表名 set 字段=新值,… where 条件
mysql> update MyClass set name='Mary' where id=1;
7、在表中增加字段
命令alter table 表名 add字段 类型 其他;
例如在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
mysql> alter table MyClass add passtest int(4) default '0'
8、更改表名
命令rename table 原表名 to 新表名;
例如在表MyClass名字更改为YouClass
mysql> rename table MyClass to YouClass;
更新字段内容
update 表名 set 字段名 = 新内容
update 表名 set 字段名 = replace(字段名,'旧内容','新内容');
文章前面加入4个空格
update article set content=concat(' ',content);
字段类型
1.INT[(M)] 型 正常大小整数类型
2.DOUBLE[(M,D)] [ZEROFILL] 型 正常大小(双精密)浮点数字类型
3.DATE 日期类型支持的范围是1000-01-01到9999-12-31。MySQL以YYYY-MM-DD格式来显示DATE值,允许你使用字符串或数字把值赋给DATE列
4.CHAR(M) 型定长字符串类型,当存储时,总是是用空格填满右边到指定的长度
5.BLOB TEXT类型,最大长度为65535(2^16-1)个字符。
6.VARCHAR型变长字符串类型
mysqldump 命令的使用
备份和导出数据库
mysqldump -h database_ip -u Username -p --opt databasename > backup-file.sql
只导出数据库表结构
mysqldump -h database_ip -d -u Username -p databasename >database_structure.sql
只导出数据库中的某个表
mysqldump --opt --add-drop-table -u Username -p databasename tablename > dump.sql
如果不想手工输入密码 请使用--password 参数
mysqldump -h database_ip -u Username --password=123456 --opt databasename > backup-file.sql
mysqldump -h database_ip -d -u Username --password=123456 databasename >database_structure.sql
mysql 命令使用
将查询结果保存到文件
select title from book into outfile '/tmp/outfile.txt';
查找表中多余的重复记录,重复记录是根据某个字段(peopleId)来判断
select from people where peopleId in (select peopleId from people group by
peopleId having count(peopleId) > 1);
查询表中不重复记录(排除重复记录)
select from phome_ecms_wma where title in (select distinct title from phome_ecms_wma);
删除表中重复记录,重复记录是根据某个字段(title)来判断
select ,count(distinct title) INTO OUTFILE '/tmp/table.bak' from phome_ecms_wma group by title;
delete from phome_ecms_wma;
LOAD DATA INFILE '/tmp/table.bak' REPLACE INTO TABLE phome_ecms_wma character set utf8;
查询数据库当前编码
mysql> show variables like "character_set%";
修改表字段类型
mysql> alter table table_name change last_action last_action datetime NOT NULL default '0000-00-00 00:00:00';
给表添加一个新字段
mysql> ALTER TABLE host ADD ks_mac VARCHAR(100);
从表中删除一个字段
mysql> ALTER TABLE table_name DROP field_name;
重命名表
mysql>alter table t1 rename t2;
给字段加索引
mysql> alter table tablename add index 索引名 (字段名1[,字段名2 …]);
mysql> alter table tablename add index emp_name (name);
加主关键字的索引
mysql> alter table tablename add primary key(id);
加唯一限制条件的索引
mysql> alter table tablename add unique emp_name2(cardnumber);
删除某个索引
mysql>alter table tablename drop index emp_name;
远程访问mysql 设置
mysql> GRANT ALL PRIVILEGES ON database_test. to root@192.168.1.9 IDENTIFIED BY '123456';
mysql> FLUSH PRIVILEGES;
1、使用SHOW语句找出在服务器上当前存在什么数据库
mysql> show databases;
2、创建一个数据库MYSQLDATA
mysql> create database mydata;
3、选择你所创建的数据库
mysql> use mydata;
4、查看现在的数据库中存在什么表
mysql> show tables;
5、创建一个数据库表
mysql> create table mytable (name varchar(20), sex char(1));
6、显示表的结构
mysql> describe mytable;
7、往表中加入记录
mysql> insert into mytable values ("test","m");
8、用文本方式将数据装入数据库表中(例如 d:\mysql.txt)
mysql> load data local infile "d:/mysql.txt" into table 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=test;
刚安装好的MySQL包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,在这里应把匿名帐户删除、root帐户设置密码,可用如下命令进行
=======================================
mysql> use mysql;
mysql> delete from User where User="";
mysql> update User set Password=PASSWORD(newpassword) where User=root;
=======================================
如果要对用户所用的登录终端进行限制,可以更新User表中相应用户的Host字段,在进行了以上更改后应重新启动数据库服务,此时登录时可用如下类似命令
=======================================
shell> mysql -uroot -p;
shell> mysql -uroot -pnewpassword;
shell> mysql mydb -uroot -p;
shell> mysql mydb -uroot -pnewpassword;
=======================================
上面命令参数是常用参数的一部分,详细情况可参考文档。此处的mydb是要登录的数据库的名称。
在进行开发和实际应用中,用户不应该只用root用户进行连接数据库,虽然使用root用户进行测试时很方便,但会给系统带来重大安全隐患,也不利于管理技术的提高。我们给一个应用中使用的用户赋予最恰当的数据库权限。如一个只进行数据插入的用户不应赋予其删除数据的权限。MySQL的用户管理是通过User表来实现的,添加新用户常用的方法有两个,一是在User表插入相应的数据行,设置相应的权限;二是通过grant命令创建具有某种权限的用户。其中grant的常用用法如下
================================================================
mysql> grant all on mydb. to NewUserName@HostName identified by "password" ;
mysql> grant usage on . to NewUserName@HostName identified by "password";
mysql> grant select,insert,update on mydb. to NewUserName@HostName identified by "password";
mysql> grant update,delete on mydb.TestTable to NewUserName@HostName identified by "password";
================================================================
若要给此用户赋予他在相应对象上的权限的管理能力,可在grant后面添加with grant option选项。而对于用插入User表添加的用户,Password字段应用password函数进行更新加密,以防不轨之人窃看密码。对于那些已经不用的用户应给予清除,权限过界的用户应及时回收权限,回收权限可以通过更新User表相应字段,也可以使用revoke操作。以下是常用权限的解释
=============================================
全局管理权限
FILE在MySQL服务器上读写文件。
PROCESS显示或杀死属于其它用户的服务线程。
RELOAD重载访问控制表,刷新日志等。
SHUTDOWN关闭MySQL服务。
数据库/数据表/数据列权限
ALTER修改已存在的数据表(例如增加/删除列)和索引。
CREATE建立新的数据库或数据表。
DELETE删除表的记录。
DROP删除数据表或数据库。
INDEX建立或删除索引。
INSERT增加表的记录。
SELECT显示/搜索表的记录。
UPDATE修改表中已存在的记录。
特别的权限
ALL允许做任何事(和root一样)。
USAGE只允许登录--其它什么也不允许做。
=============================================
MySQL常用操作基本操作,以下都是MySQL5.0下测试通过说明下,记住在每个命令结束时加上;(分号)
1.导出整个数据库
mysqldump -u 用户名 -p --default-character-set=latin1 数据库名 > 导出的文件名(数据库默认编码是latin1)
mysqldump -u wc -p smgp_apps_wc > wc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u wc -p smgp_apps_wc users> wc_users.sql
3.导出一个数据库结构
mysqldump -u wc -p -d –add-drop-table smgp_apps_wc >d:wc_db.sql
-d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table
4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:wc_db.sql
1、进入MySQL启动MySQL Command Line Client(MySQL的DOS界面),直接输入安装时的密码即可。此时的提示符是mysql>
2、退出MySQLquit或exit
二、库操作
1、、创建数据库
命令create database <数据库名>
例如建立一个名为xhkdb的数据库
mysql> create database xhkdb;
2、显示所有的数据库
命令show databases (注意有个s)
mysql> show databases;
3、删除数据库
命令drop database <数据库名>
例如删除名为 xhkdb的数据库
mysql> drop database xhkdb;
4、连接数据库
命令 use <数据库名>
例如如果xhkdb数据库存在,尝试存取它
mysql> use xhkdb;
屏幕提示Database changed
5、当前选择(连接)的数据库
mysql> select database();
6、当前数据库包含的表信息
mysql> show tables; (注意有个s)
三、表操作,操作之前应连接某个数据库
1、建表
命令create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
mysql> create table MyClass(
> id int(4) not null primary key auto_increment,
> name char(20) not null,
> sex int(4) not null default '0',
> degree double(16,2));
2、获取表结构
命令 desc 表名,或者show columns from 表名
mysql> desc MyClass;
mysql> show columns from MyClass;
3、删除表
命令drop table <表名>
例如删除表名为 MyClass 的表
mysql> drop table MyClass;
4、插入数据
命令insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]
例如,往表 MyClass中插入二条记录, 这二条记录表示编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5.
mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);
5、查询表中的数据
1)、查询所有行
命令 select <字段1,字段2,...> from < 表名 > where < 表达式 >
例如查看表 MyClass 中所有数据
mysql> select from MyClass;
2)、查询前几行数据
例如查看表 MyClass 中前2行数据
mysql> select from MyClass order by id limit 0,2;
6、删除表中数据
命令delete from 表名 where 表达式
例如删除表 MyClass中编号为1 的记录
mysql> delete from MyClass where id=1;
7、修改表中数据update 表名 set 字段=新值,… where 条件
mysql> update MyClass set name='Mary' where id=1;
7、在表中增加字段
命令alter table 表名 add字段 类型 其他;
例如在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
mysql> alter table MyClass add passtest int(4) default '0'
8、更改表名
命令rename table 原表名 to 新表名;
例如在表MyClass名字更改为YouClass
mysql> rename table MyClass to YouClass;
更新字段内容
update 表名 set 字段名 = 新内容
update 表名 set 字段名 = replace(字段名,'旧内容','新内容');
文章前面加入4个空格
update article set content=concat(' ',content);
字段类型
1.INT[(M)] 型 正常大小整数类型
2.DOUBLE[(M,D)] [ZEROFILL] 型 正常大小(双精密)浮点数字类型
3.DATE 日期类型支持的范围是1000-01-01到9999-12-31。MySQL以YYYY-MM-DD格式来显示DATE值,允许你使用字符串或数字把值赋给DATE列
4.CHAR(M) 型定长字符串类型,当存储时,总是是用空格填满右边到指定的长度
5.BLOB TEXT类型,最大长度为65535(2^16-1)个字符。
6.VARCHAR型变长字符串类型
mysqldump 命令的使用
备份和导出数据库
mysqldump -h database_ip -u Username -p --opt databasename > backup-file.sql
只导出数据库表结构
mysqldump -h database_ip -d -u Username -p databasename >database_structure.sql
只导出数据库中的某个表
mysqldump --opt --add-drop-table -u Username -p databasename tablename > dump.sql
如果不想手工输入密码 请使用--password 参数
mysqldump -h database_ip -u Username --password=123456 --opt databasename > backup-file.sql
mysqldump -h database_ip -d -u Username --password=123456 databasename >database_structure.sql
mysql 命令使用
将查询结果保存到文件
select title from book into outfile '/tmp/outfile.txt';
查找表中多余的重复记录,重复记录是根据某个字段(peopleId)来判断
select from people where peopleId in (select peopleId from people group by
peopleId having count(peopleId) > 1);
查询表中不重复记录(排除重复记录)
select from phome_ecms_wma where title in (select distinct title from phome_ecms_wma);
删除表中重复记录,重复记录是根据某个字段(title)来判断
select ,count(distinct title) INTO OUTFILE '/tmp/table.bak' from phome_ecms_wma group by title;
delete from phome_ecms_wma;
LOAD DATA INFILE '/tmp/table.bak' REPLACE INTO TABLE phome_ecms_wma character set utf8;
查询数据库当前编码
mysql> show variables like "character_set%";
修改表字段类型
mysql> alter table table_name change last_action last_action datetime NOT NULL default '0000-00-00 00:00:00';
给表添加一个新字段
mysql> ALTER TABLE host ADD ks_mac VARCHAR(100);
从表中删除一个字段
mysql> ALTER TABLE table_name DROP field_name;
重命名表
mysql>alter table t1 rename t2;
给字段加索引
mysql> alter table tablename add index 索引名 (字段名1[,字段名2 …]);
mysql> alter table tablename add index emp_name (name);
加主关键字的索引
mysql> alter table tablename add primary key(id);
加唯一限制条件的索引
mysql> alter table tablename add unique emp_name2(cardnumber);
删除某个索引
mysql>alter table tablename drop index emp_name;
远程访问mysql 设置
mysql> GRANT ALL PRIVILEGES ON database_test. to root@192.168.1.9 IDENTIFIED BY '123456';
mysql> FLUSH PRIVILEGES;
1、使用SHOW语句找出在服务器上当前存在什么数据库
mysql> show databases;
2、创建一个数据库MYSQLDATA
mysql> create database mydata;
3、选择你所创建的数据库
mysql> use mydata;
4、查看现在的数据库中存在什么表
mysql> show tables;
5、创建一个数据库表
mysql> create table mytable (name varchar(20), sex char(1));
6、显示表的结构
mysql> describe mytable;
7、往表中加入记录
mysql> insert into mytable values ("test","m");
8、用文本方式将数据装入数据库表中(例如 d:\mysql.txt)
mysql> load data local infile "d:/mysql.txt" into table 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=test;
刚安装好的MySQL包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,在这里应把匿名帐户删除、root帐户设置密码,可用如下命令进行
=======================================
mysql> use mysql;
mysql> delete from User where User="";
mysql> update User set Password=PASSWORD(newpassword) where User=root;
=======================================
如果要对用户所用的登录终端进行限制,可以更新User表中相应用户的Host字段,在进行了以上更改后应重新启动数据库服务,此时登录时可用如下类似命令
=======================================
shell> mysql -uroot -p;
shell> mysql -uroot -pnewpassword;
shell> mysql mydb -uroot -p;
shell> mysql mydb -uroot -pnewpassword;
=======================================
上面命令参数是常用参数的一部分,详细情况可参考文档。此处的mydb是要登录的数据库的名称。
在进行开发和实际应用中,用户不应该只用root用户进行连接数据库,虽然使用root用户进行测试时很方便,但会给系统带来重大安全隐患,也不利于管理技术的提高。我们给一个应用中使用的用户赋予最恰当的数据库权限。如一个只进行数据插入的用户不应赋予其删除数据的权限。MySQL的用户管理是通过User表来实现的,添加新用户常用的方法有两个,一是在User表插入相应的数据行,设置相应的权限;二是通过grant命令创建具有某种权限的用户。其中grant的常用用法如下
================================================================
mysql> grant all on mydb. to NewUserName@HostName identified by "password" ;
mysql> grant usage on . to NewUserName@HostName identified by "password";
mysql> grant select,insert,update on mydb. to NewUserName@HostName identified by "password";
mysql> grant update,delete on mydb.TestTable to NewUserName@HostName identified by "password";
================================================================
若要给此用户赋予他在相应对象上的权限的管理能力,可在grant后面添加with grant option选项。而对于用插入User表添加的用户,Password字段应用password函数进行更新加密,以防不轨之人窃看密码。对于那些已经不用的用户应给予清除,权限过界的用户应及时回收权限,回收权限可以通过更新User表相应字段,也可以使用revoke操作。以下是常用权限的解释
=============================================
全局管理权限
FILE在MySQL服务器上读写文件。
PROCESS显示或杀死属于其它用户的服务线程。
RELOAD重载访问控制表,刷新日志等。
SHUTDOWN关闭MySQL服务。
数据库/数据表/数据列权限
ALTER修改已存在的数据表(例如增加/删除列)和索引。
CREATE建立新的数据库或数据表。
DELETE删除表的记录。
DROP删除数据表或数据库。
INDEX建立或删除索引。
INSERT增加表的记录。
SELECT显示/搜索表的记录。
UPDATE修改表中已存在的记录。
特别的权限
ALL允许做任何事(和root一样)。
USAGE只允许登录--其它什么也不允许做。
=============================================
MySQL常用操作基本操作,以下都是MySQL5.0下测试通过说明下,记住在每个命令结束时加上;(分号)
1.导出整个数据库
mysqldump -u 用户名 -p --default-character-set=latin1 数据库名 > 导出的文件名(数据库默认编码是latin1)
mysqldump -u wc -p smgp_apps_wc > wc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u wc -p smgp_apps_wc users> wc_users.sql
3.导出一个数据库结构
mysqldump -u wc -p -d –add-drop-table smgp_apps_wc >d:wc_db.sql
-d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table
4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:wc_db.sql
上一篇:通过SQL语句来备份,还原数据库
下一篇:win32安装配置非安装版的MySQL
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程