MySQL是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 是现在最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。
MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
英文在线文档:http://dev.mysql.com/doc/
中文在线文档5.1版:http://tool.oschina.net/apidocs/apidoc?api=mysql-5.1-zh
http://jingyan.baidu.com/article/7e440953d6f0702fc1e2ef61.html
在配置好MySQL的path路径后,可以在DOS命令行下输入mysql -u 用户名 -p,然后回车输入密码,登录进MySQL控制台。
PS:推荐使用图形管理工具Navicat for MySQL对MySQL数据库进行操作。
-- 创建数据库 mydb1 CREATE DATABASE mydb1; -- 创建字符集为utf - 8的数据库 CREATE DATABASE mydb2 CHARACTER SET utf8; -- 创建字符集为utf - 8校对规则为utf8_general_ci CREATE DATABASE mydb3 CHARACTER SET utf8 COLLATE utf8_general_ci; -- 显示所有数据库 SHOW DATABASES; -- 显示创建数据库指令 SHOW CREATE DATABASE mydb1; SHOW CREATE DATABASE mydb2; -- 删除数据库mydb3 DROP DATABASE mydb3; -- 修改数据库 ALTER DATABASE mydb1 CHARACTER SET utf8 COLLATE utf8_general_ci; -- 备份数据库mydb2 -- 该语句需要在dos环境下使用 mysqldump -u root -p mydb2 > c:/mydb2.sql -- 删除数据库mydb2 DROP DATABASE mydb2; -- 恢复数据库 -- 需要先创建同名数据库mydb2 CREATE DATABASE mydb2 CHARACTER SET utf8; -- 然后用source命令,这条语句是要在mysql控制台下的mydb2数据库下使用的 USE mydb2; SOURCE c:/mydb2.sql -- 指定使用数据库mydb2 USE mydb2;
-- 创建users表 CREATE TABLE users ( userId INT, name VARCHAR(32) );
该段为官方文档使用方法
-- 定义新表 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name [(create_definition,...)] [table_options] [select_statement] 或: -- 复制旧表 CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name [(] LIKE old_tbl_name [)];
常用方法
-- 添加新的列 alter table 表名 addd 列名 数据类型 -- 修改列(列的类型和大小) alter table 表名 modify 列名 新的数据类型 -- 删除某列 alter table 表名 drop 列名 alter table 表名rename to 新表名 alter table 表名 character set 字符集名; alter table users change column name username varchar(20);
该段为官方文档使用方法
ALTER [IGNORE] TABLE tbl_name alter_specification [, alter_specification] ... alter_specification: ADD [COLUMN] column_definition [FIRST | AFTER col_name ] | ADD [COLUMN] (column_definition,...) | ADD INDEX [index_name] [index_type] (index_col_name,...) | ADD [CONSTRAINT [symbol]] PRIMARY KEY [index_type] (index_col_name,...) | ADD [CONSTRAINT [symbol]] UNIQUE [index_name] [index_type] (index_col_name,...) | ADD [FULLTEXT|SPATIAL] [index_name] (index_col_name,...) | ADD [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name,...) [reference_definition] | ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT} | CHANGE [COLUMN] old_col_name column_definition [FIRST|AFTER col_name] | MODIFY [COLUMN] column_definition [FIRST | AFTER col_name] | DROP [COLUMN] col_name | DROP PRIMARY KEY | DROP INDEX index_name | DROP FOREIGN KEY fk_symbol | DISABLE KEYS | ENABLE KEYS | RENAME [TO] new_tbl_name | ORDER BY col_name | CONVERT TO CHARACTER SET charset_name [COLLATE collation_name] | [DEFAULT] CHARACTER SET charset_name [COLLATE collation_name] | DISCARD TABLESPACE | IMPORT TABLESPACE | table_options | partition_options | ADD PARTITION partition_definition | DROP PARTITION partition_names | COALESCE PARTITION number | REORGANIZE PARTITION partition_names INTO (partition_definitions) | ANALYZE PARTITION partition_names | CHECK PARTITION partition_names | OPTIMIZE PARTITION partition_names | REBUILD PARTITION partition_names | REPAIR PARTITION partition_names
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ... [RESTRICT | CASCADE]
DROP TABLE用于删除一个或多个表。您必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心!
RENAME TABLE tbl_name TO new_tbl_name [, tbl_name2 TO new_tbl_name2] ...
本语句用于对一个或多个表进行重命名。
案例:
-- 在上面员工表的基本上增加一个image列。 alter table emp add image blob; -- 修改job列,使其长度为60。 alter table emp modify job varchar(60); -- 删除sex列。 alter table emp drop sex; -- 表名改为user。 rename table emp to user; -- 修改表的字符集为utf-8 alter table user character set utf8; -- 列名name修改为username alter table user change column name username varchar(30); -- 如何显示创建表的指令: show create table 表名; -- 显示当前数据库的所有表 SHOW TABLES;
数据库的DML语句基本和oracle数据库一致,故不在赘述,这里放上以前写的博客《Oracle表管理》,地址为:http://blog.csdn.net/q547550831/article/details/49964047#t12