挺全的一个mysql基础教学文档

3086阅读 0评论2012-03-20 RSroad
分类:Mysql/postgreSQL


 mysql修改表名,列名,列类型,添加表列,删除表列 java 连接SQL Server2000 最新驱动
mysql 控制台操作 mysql 取消主键  

2010-10-25 16:34:24|  分类: 数据库 |  标签:语法  数值  代码  mysql  table   |字号 订阅
2.1登入到mysql控制台[用户名为root,密码缺省为空] 
  切换到mysql的bin目录cd d:wampmysqlin 
  登入到mysql控制台 
  语法:mysql -h hostname -u username -p 
  连接到另一台主机 
  代码:mysql -h 192.168.1.1 -u root -p 
  password:直接按回车 
  连接到本机 
  代码:mysql -h 127.0.0.1 -u root -p 
  password:直接按回车 
  呈现mysql>暗示登陆到mysql控制台乐成 
  2.2退出mysql控制台 
  mysql>exit; 
  /************************************************* **********/ 

3.1检查所有mysql数值库清单; 
  语法:mysql> show databases; 
  代码:mysql> show databases; 
  3.2预示数值库中所有表的清单 
  查看时下数值库中的表 
  语法1:mysql> show tables; 
  代码1:mysql> show tables; 
  3.3查看其他数值库jxc中的表 
  语法1:mysql> show tables from databasename; 
  代码1:mysql> show tables from jxc; 
  /************************************************* **********/ 

4.创建/删除/选择数值库 
  创建jxc数值库: 
  语法:mysql> create database databasename; 
  代码:mysql> create database jxc; 
  删除jxc数值库: 
  语法:mysql> drop database databasename; 
  代码:mysql> create database abc; 
  代码:mysql> drop database abc; 
  选择jxc数值库: 
  语法:mysql> use database; 
  代码:mysql> use jxc; 
  /************************************************* **********/ 
5查看一个表的数值结构 
  5.1 describte查看表customers结构 
  语法1:mysql> describe tablename; 
  代码1:mysql> describe customers; 
  5.2.show columns查看表customers;结构 
  语法1:mysql> show columns from tablename; 
  代码1:mysql> show columns from customers; 
  5.3.查看一个表的指定列名的数值结构 
  语法1:mysql> show index from tablename column; 
  代码1:mysql> show index from customers name; 
  5.4.查看一个表customers的索引 
  语法1:mysql> show index from tablename; 
  代码1:mysql> show index from customers; 

6.数值常用操作(select,insert,update,delete) 
  6.1 select选择: 
  语法:select * from [表名1,表名1,,,] where [前提规模] 
  代码:select * from orders where orderid>100; 
  6.2 insert插进去 
  语法:insert into table1(column1,column,,,) values(value1,value2,,,); 
  代码:insert into books(isbn,author,title,price) values('iso-902126','jahn.D','mysql6.0',99.0); 
  6.3 update 更新: 
  语法:update table1 set [列名]=[新数值] where [前提规模] 
  代码:update books set title="Thellonking in Java" where isbn='iso-902126'; 
  6.4删除: 语法:delete from [表名] where [前提规模] 
  代码:delete from books where isbn='iso-902126'; 
  6.5其他方法 
  查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙 
  排序:select * from table1 order by field1,field2 [desc] 
  总额:select count as totalcount from table1 
  求和:select sum(field1) as sumvalue from table1 
  平均:select avg(field1) as avgvalue from table1 
  最大:select max(field1) as maxvalue from table1 
  最小:select min(field1) as minvalue from table1 
  /************************************************* **********/ 

7.用grant创建数值库的用户和权限 
  GRANT命令语法: 
  GRANT [许可权列表1],[许可权列表2] 
  ON [数值库.表名] 
  TO [用户名@主机名] 
  IDENTIFIED BY '密码'; 
  代码使成为事实1: 
  grant select,insert,delete,update 
  on discuz.* to 
  identified by '201314'; 
  功效说明 
  把在数值库discuz所有表的select,insert,delete,update这四个权限 
  添加到新用户jake,密码为'201314'; 
  代码使成为事实2: 
  grant all 
  on discuz.* to 
  identified by '123456'; 
  把在数值库discuz全部权限所有表添加到新用户tom,密码为'123456'; 
  [许可权列表1]选项如次 
  select 表,列 
  insert 表,列 
  udpate 表,列 
  delete 表 
  index 表 
  alter 表 
  create 数值库,表 
  drop 数值库,表 
  [许可权列表2]选项如次 
  create temporary tables 允许使用temporary关键字 
  file 允许数值库导入和导出到文件 
  lock tables 允许使用lock talbes命令 
  reload 允许重新载入授权表 
  show databases 允许查看所有的数值库清单 
  shutdown 允许使用关闭MYSQL 
  all 上面所以权限 
  美国ge 允许只登录,但不允许不论什么操作 
  [数值库.表名]选项如次 
  数值库.表名 选择数值库中一个表给XX用户 
  数值库.* 选择数值库中所有表给XX用户 
  /************************************************* **********/ 

8.revoke勾销用户和用户权限 
  revoke格式: 
  revoke [许可权列表1],[许可权列表2] privileges,[columns] 
  ON [数值库.表名] 
  FROM [用户名@主机名] 
  代码: 
  先授权给laoliu(老刘) 
  grant all 
  on books.* 
  to laoliu identified by 'laoliu11'; 撒去一部分权限 
  revoke alter,create,drop 
  on books.* 
  from laoliu; 
  撒去laoliu的所有权限 
  revoke all 
  on books.* 
  from laoliu; 
  /************************************************* **********/ 

9.添加MYSQL用户其他方法 
  shell> mysql -u root -p1234 mysql 
  mysql> insert into user(Host,User,Password) values ('localhost','backup','databse'); 
  添加一个来自本机的mysql 用户backup,口令为:1234 
  shell>mysql –u root –p 
  mysql>GRANT FILE ON *.* TO IDENTIFIED BY '1234'; 
  mysql>exit 
  开放一个账号backup密码1234给来自IP:192.168.1.200有档案处置惩罚的权限 
  /************************************************* **********/ 

10.创建表/修改表/删除表//优化表 
  10.1创建表 
  语法:create table tablename(columns,...) 
  代码: 
  create table order_items 
  (orderid int unsigned not null, 
  isbn char⒀ not null, 
  quantity tinyint unsigned, 
  primary key (orderid,isbn) 
  ); 
  10.2修改表 
  10.2.1添加/删除一列 
  语法:alter table [表名] add column [列名] [类型]; 
  在表中添加一列remark 
  代码:alter table order_items add column remark char(50); 
  删除一列 
  语法:alter table [表名] drop column [列名]; 
  从表中删除一列remark 
  alter table order_items drop column remark; 
  10.2.2添加/删除主键 
  添加orderid,isbn为主键 
  语法:alter table [表名] add primary key [列名1,列名1]; 
  代码:alter table order_items add primary key (orderid,isbn); 
  删除主键 
  语法:alter table [表名] drop primary key 
  代码:Alter table tabname drop primary key 
  10.2.3建立/删除索引 
  建立索引 
  语法:create index [索引名] on [表名] (列名); 
  代码:create index orderid_ix on orders (orderid); 
  删除索引 
  语法:drop index [索引名] on [表名] (列名); 
  代码:drop index orderid_ix on orders; 
  10.3删除表: 
  删除表 
  语法:drop table [表名] 
  代码:drop table orders; 
  10.4优化表: 
  当一个表的数值有上万行,拜候速率减慢,就必需为它们举行优化 
  通常的方式是做出一个optmize.sql文件, 
  直接导入这个优化脚本文件举行批量优化一些关键的表,以提高拜候速率 
  优化表customers数值(customers) 
  语法:mysql>optmize table tablename; 代码:mysql>optmize table customers; 10.5 用命令行加载一个new_tb.sql文件 
  从而让MYSQL一次批量执行上*SQL文件中的在量的sql语句 
  1.文本文件做好sql命令调集,然后复制到命令行一个个的执行 
  2.要是表太多的话,直接存为*.sql文件,然后用命令装入文件 
  格式: mysql -h [主机IP] -u [用户名] -D [数值库名] -p < [此目录中的*.sql文件名] 
  运行cmd 
  cd d:wampmysqlin 
  mysql -h 127.0.0.1 -u root -D pubs -p P> 
  上面就是用mysql把d:wampmysqlin ew_tb.sql文件加载到books数值库, 
  注意:数值库pubs必需存在和-D要大写 
  new_tb.sql文件内容(此文件的SQL命令是可以存上1000条以上的) 
  create table customers 
  (customerid int unsigned not null auto_increment primary key, 
  name char(50) not null, 
  address char(100) not null, 
  city char(30) not null 
  ); 
  create table orders 
  (orderid int unsigned not null auto_increment primary key, 
  customerid int unsigned not null, 
  amount float(6,2), 
  date date not null 
  ); 
  create table books 
  (isbn char⒀ not null primary key, 
  author char(50), 
  title char(100), 
  price float(6,2) 
  ); 
  create table order_items 
  (orderid int unsigned not null, 
  isbn char⒀ not null, 
  quantity tinyint unsigned, 
  primary key (orderid,isbn) 
  ); 
  create table book_reviews 
  (isbn char⒀ not null primary key, 
  review text 
  ); 
  执行OK后,再举行检查表是否AUTO建立OK? 
  c:>mysql -h 127.0.0.1 -u root -p 
  mysql>show tables from pubs; 
  结果预示以上5个表都已经建立OK; 
  /************************************************* **********/ 

11.表的视图建立与删除 
  建立视图 
  语法:create iview [视图名] as [select 语句); 
  代码:create view v_orders as select * from orders; 
  删除视图 
  语法:drop iview [视图名] 
  代码:create view v_orders 

原文地址:http://blog.163.com/xiaohui_1123@126/blog/static/39805240201092543424941/
上一篇:System.out.println()和System.out.write()的区别.
下一篇:你的人生中看过多少次日出?