mysql基本命令总结

21 篇文章 0 订阅

数据库asb 表yg
一.mysql的常用命令
1.create database name; 创建数据库 (create 内部命令)
mysql>create database asb;
2.use databasename; 选择数据库 (use内部命令)
mysql>use asb;
3.drop database name 直接删除数据库,不提醒 (drop内部命令)
mysql>drop database asb;
4.drop table name 直接删除表
mysql>drop table yg;
5.create table name;创建表
mysql>create table yg;
前提是先mysql>use asb;
6.show databases显示所有数据库 
mysql>show databases;
7.show tables; 显示数据库中的表 (show内部命令)
mysql>show tables;
提是先mysql>use asb;
8.describe tablename; 显示表的详细描述 
mysql>describe yg;
9.select version(),current_date; 显示当前mysql版本和当前日期
mysql>select version(),current_date;
mysql>select version(),
      ->current_date;
select 内部命令 
10.mysql>flush privileges 刷新数据库 
11.mysql实现修改用户密码:
11.1 update 修改
shell>mysql -u root -p 
mysql> update mysql.user set password=PASSWORD(’新密码’) where User='root'; 
mysql> flush privileges; 
mysql> quit 
11.2 mysqladmin修改用户密码
shell>mysqladmin -u root password new_password 
***11.3 自己测试未通过
shell>mysql -u root -p
mysql>SET PASSWORD FOR root=PASSWORD("root");
12.创建帐号
mysql> grant all(delete,updatae,create,drop,insert) privileges on *.* to 用户@localhost identified by '密码';
13.重命名表: 
mysql > alter table t1 rename t2; 把表t1重命名为t2
14.备份数据库
14.1 导出整个数据库
 mysqldump -u 用户名 -p 数据库名 > 导出的文件名
 mysqldump -u root -p asb >d:\asb.sql
14.2 导出一个表
 mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
 mysqldump -u root -p asb yg>d:\yg.sql
14.3 导出一个数据库结构
 mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:\wcnc_db.sql(-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table)
mysqldump mysqladmin外部命令
14.4 导入数据库
用source 命令
进入mysql数据库控制台,先建立数据库,use数据库
mysql -u root -p
mysql>create asb;
mysql>use 数据库
mydql>source d:\asb.sql;
14.5 导入表
进入数据库,执行导入操作
mysql>use asb;
mysql>source d:\yg.sql; 
15.将表中记录清空:
mysql>delete from yg;
16.显示表中的记录:
mysql>select * from yg;
17.一个建库和建表以及插入数据的实例
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 in,然后键入以下命令:
mysql -uroot -p密码 < c:school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你
只要将//的注释去掉即可使用)。
将文本数据转到数据库中
文本数据应符合的格式:字段数据之间用tab键隔开,null值用来代替。例:
3 rose 深圳二中 1976-10-10
4 mike 深圳一中 1975-12-23
数据传入命令load data local infile "文件名" into table 表名;
注意:你最好将文件复制到mysql in目录下,并且要先用use命令选表所在的库。
*18.revoke all on database from user 移除user用户在database数据库上的所有权限 (自己测试未通过)
19.连接mysql。
格式: mysql -h主机地址 -u用户名 -p用户密码
20.登录数据库
mysql-uroot-p;
mysql-uroot-pnewpassword;
mysqlmydb-uroot-p;
mysql mydb -uroot -pnewpassword;
mydb数据库名
21.刚安装好的MySql包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,   在这里应把匿名帐户删除、root帐户设置密码,可用如下命令进行:
mysql>use mysql;
mysql>delete from User where User="";
mysql>update User set Password=PASSWORD('newpassword') where User='root';
22.新增用户
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码" 
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令: 
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页来访问。 
mysql>grant select,insert,update,delete on mydb.* to  test2@localhost  identified by "abc";
如果你不想test2有密码,可以再打一个命令将密码消掉。 
mysql>grant select,insert,update,delete on mydb.* to  test2@localhost  identified by "";
下面我们来看看MySQL中有关数据库方面的操作。注意:你必须首先登录到MySQL中,以下操作都是在MySQL的提示符下进行的,而且每个命令以分号结束。 
在进行开发和实际应用中,用户不应该只用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";
23.对常用权限的解释:
   23.1 全局管理权限: 
FILE:在MySQL服务器上读写文件。 
PROCESS:显示或杀死属于其它用户的服务线程。 
RELOAD:重载访问控制表,刷新日志等。 
SHUTDOWN:关闭MySQL服务。
23.2 数据库/数据表/数据列权限: 
Alter:修改已存在的数据表(例如增加/删除列)和索引。 
Create:建立新的数据库或数据表。 
Delete:删除表的记录。 
Drop:删除数据表或数据库。 
INDEX:建立或删除索引。 
Insert:增加表的记录。 
Select:显示/搜索表的记录。 
Update:修改表中已存在的记录。
23.3 特别的权限: 
ALL:允许做任何事(和root一样)。 
USAGE:只允许登录--其它什么也不允许做。
 
最后给出在RedHat9.0下的MySql操作演示:
选用数据库的root用户登录
[weiwen@weiwenlinux]$mysql -uroot -p
Enterpassword:MyPassword
mysql>create database mydb;
QueryOK,1rowaffected(0.02sec)
mysql>use mydb;
Databasechanged
mysql>create table TestTable(Idintaut_increment primary key,
UserNamevarchar(16) not null,
Address varchar(255));
QueryOK,0rowsaffected(0.02sec)
mysql>grant all on mydb.* to  test@localhost  identified by "test";
QueryOK,0rowsaffected(0.01sec)
mysql>quit
Bye
[weiwen@weiwenlinux]$mysqlmydb -utest -ptest
其中test.sql是用vi编辑好的SQL脚本,其内容为:
Insert into TestTable(UserName,Address) values('Tom','shanghai');
Insert into TestTable(UserName,Address) values('John','beijing');
select * from TestTable;
运行已经编辑好的SQL脚本可以用source filename或.filename。
以上只是对新手的简单练习,要成为一个数据库好手,当以孜孜不倦地追求知识,不断地思考、尝试、再思考。
24.MySql常用命令总结 
24.1 使用SHOW语句找出在服务器上当前存在什么数据库: 
mysql>SHOW DATABASES;  
24.2 创建一个数据库MYSQLDATA 
mysql>Create DATABASE MYSQLDATA; 
24.3 选择你所创建的数据库 
mysql>USE MYSQLDATA;(按回车键出现Databasechanged时说明操作成功!)  
24.4 查看现在的数据库中存在什么表 
mysql>SHOW TABLES;  
24.5 创建一个数据库表 
mysql>Create TABLEMYTABLE(name VARCHAR(20),sex CHAR(1));  
24.6 显示表的结构: 
mysql>DESCRIBE MYTABLE; 
24.7 往表中加入记录 
mysql>insert into MYTABLE values("hyq","M");  
24.8 用文本方式将数据装入数据库表中(例如D:/mysql.txt) 
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;  
24.9 导入.sql文件命令(例如D:/mysql.sql) 
mysql>use database; 
mysql>source d:/mysql.sql; 
24.10 删除表 
mysql>drop TABLE MYTABLE;  
24.11 清空表 
mysql>delete from MYTABLE;  
24.12 更新表中数据 
mysql>update MYTABLE set sex="f" where name='hyq'; 
25.启动mysql
25.1安装删除mysql服务,系统盘下windows文件夹下my.ini文件,设置mysql的路径等功能
my.ini文件配置如下:
[mysqld]
basedir=D:/Program Files/mysql
#bind-address=ip
datadir=D:/Program Files/mysql/data
#language=D:/Program Files/mysql/share/your language directory
#slow query log#=
#tmpdir#=
#port=3306
set-variable    = max_connections=1500
skip-locking
#skip-networking
set-variable        = key_buffer=384M
set-variable        = max_allowed_packet=1M
set-variable        = table_cache=512
set-variable        = sort_buffer=2M
set-variable        = record_buffer=2M
set-variable        = thread_cache=8
# Try number of CPU's*2 for thread_concurrency
set-variable        = thread_concurrency=8
set-variable        = myisam_sort_buffer_size=64M
#set-variable        = connect_timeout=5
#set-variable        = wait_timeout=5
server-id        = 1
[isamchk]
set-variable        = key_buffer=128M
set-variable        = sort_buffer=128M
set-variable        = read_buffer=2M
set-variable        = write_buffer=2M

[myisamchk]
set-variable        = key_buffer=128M
set-variable        = sort_buffer=128M
set-variable        = read_buffer=2M
set-variable        = write_buffer=2M
[WinMySQLadmin]
Server=D:/Program Files/mysql/bin/mysqld-nt.exe
安装mysql服务命令,进入mysql安装目录bin下:
mysqld-nt -install
删除mysql服务
mysqld-nt -remove
25.2 启动停止mysql
启动mysql
进入mysql安装目录bin下:
net start mysql
停止mysql
net stop mysql
26. 给表改名: 
mysql>RENAME TABLE ztemp TO ztemp4;
27. 修改字段属性: 
mysql>ALTER TABLE bbabase CHANGE news_id id VARCHAR(5) NOT NULL;
28. 在表中的content后增加一字段: 
mysql>ALTER TABLE bbabase ADD leave_time DATETIME NOT NULL AFTER content;
29. SHOW STATUS命令获得一份服务器运行与统计的报告,包括打开连接的次数,激活查询次数,服务器正常运行时间等等。
mysql> SHOW STATUS;
+------------------+-------+
| Variable_name| Value |
+------------------+-------+
| Aborted_clients| 0|
| Aborted_connects | 0|
...
| Uptime| 851|
+------------------+-------+
156 rows in set (0.16 sec)
二.学习网站 资源下载
主要为mysql+tomcat+apache资源,此外还有其他,具体自己体验。
apache学习网站
http://lamp.linux.gov.cn/Apache/ApacheMenu/
http://www.qqread.com/z/apache/
http://www.qqread.com/
mysql学习网站
http://www.javaeye.com/wiki/topic/154928
http://www.javaeye.com/
*****http://www.soidc.net/search_article.shtml?wo=mysql%B2%BB%CA%C7%C4%DA%B2%BF%BB%F2%CD%E2%B2%BF%C3%FC%C1%EE
http://www.soidc.net
mysql下载
******http://www.codepub.com/software/index.html
Apache 2.2.4
下载地址: http://cztele1.skycn.com/down/apache_2.2.4-win32-x86-no_ssl.zip
Tomcat 6.0.16
下载地址: http://apache.mirror.phpchina.co  ... e-tomcat-6.0.16.zip
JDK
下载地址: http://cds.sun.com/is-bin/INTERS  ... -windows-i586-p.exe
如果只是应用的话,也可以选择安装JRE,因为JRE比较小:)
JK-1.2.26-httpd-2.2.4
下载地址: http://www.apache.org/dist/tomca  ... 2.26-httpd-2.2.4.so
注意JK的版本一定要与Apache版本相同。如果你的版本与我的不同,可以去官网下载,有多种版本,适用于各种操作系统,下载适用的既可,地址:
http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/
http://blog.csdn.net/gztoby/archive/2004/09/02/92279.aspx
Tomcat中文手册:ttp://www.channel7.cn/2004/10-18/212955.html
Eclipse Tomcat集成开发servlet: http://www.blogdriver.com/chian/329839.html
Eclipse+Tomcat集成开发servlet: http://ezo.biz/b/archives/2004/06/54.html


CREATE TABLE  `test`.`user` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(32) DEFAULT NULL COMMENT '名字',
  `role_id` int(11) DEFAULT NULL COMMENT '外键-角色ID',
  `create_time` datetime DEFAULT NULL COMMENT '创建时间',
  `descript` varchar(128) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `new_fk_constraint` (`role_id`),
  CONSTRAINT `new_fk_constraint` FOREIGN KEY (`role_id`) REFERENCES `role` (`id`) ON DELETE SET NULL
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='用户表'

CREATE TABLE  `test`.`role` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(32) DEFAULT NULL COMMENT '名字',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='角色信息'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值