MySQL入门

MySQL入门

基本概述

    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使用

    在配置好MySQLpath路径后,可以在DOS命令行下输入mysql -u 用户名 -p,然后回车输入密码,登录进MySQL控制台。

PS:推荐使用图形管理工具Navicat for MySQLMySQL数据库进行操作。

 

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;

MySQL数据库表DDL语句

Create使用
-- 创建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使用

常用方法

-- 添加新的列
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使用
DROP [TEMPORARY] TABLE [IF EXISTS]
    tbl_name [, tbl_name] ...
    [RESTRICT | CASCADE]

DROP TABLE用于删除一个或多个表。您必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心!


RENAME使用
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;

MySQL数据库表DML语句

    数据库的DML语句基本和oracle数据库一致,故不在赘述,这里放上以前写的博客《Oracle表管理》,地址为:http://blog.csdn.net/q547550831/article/details/49964047#t12


MySQL分页查询

    分页查询使用的是limit关键字进行查询。它后面有两个参数。第一个参数是起始的位置(取值为:(页数-1)*每页条目数),第二个参数是每页需要显示的条目数。

 

举例:商品表中有10条记录,现在需要进行分页显示,每页显示3条数据。现在需要查看第二页的数据。那么应该使用的sql语句是:

select * from product limit 3,3;

SQL执行顺序

参考:sql执行顺序




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值