安装
yum install mysql
yum install mysql-server
yum install mysql-devel
启停
service mysqld start
ps -ef | grep mysqld
root@host# cd /usr/bin
./mysqladmin -u root -p shutdown
Enter password: ******
修改root密码
mysqladmin -u root password "new_password";
[root@host]# mysql -u root -p
Enter password:*******
创建用户
. 方法1:在 mysql 数据库中的 user 表添加新用户
root@host# mysql -u root -p
Enter password:*******
mysql> use mysql;
Database changed
mysql> INSERT INTO user
(host, user, password,
select_priv, insert_priv, update_priv)
VALUES ('localhost', 'guest',
PASSWORD('guest123'), 'Y', 'Y', 'Y');
Query OK, 1 row affected (0.20 sec)
mysql> FLUSH PRIVILEGES;
. 方法2:通过SQL的 GRANT 命令
mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP
-> ON TUTORIALS.*
-> TO 'zara'@'localhost'
-> IDENTIFIED BY 'zara123';
常用命令
. show databases
. use 数据库名
. show tables
. show columns from 表名
. show index from 表名
. SHOW TABLE STATUS LIKE [FROM db_name] [LIKE 'pattern'] \G: 该命令将输出Mysql数据库管理系统的性能及统计信息。
. show grants;查看当前用户(自己)权限:
. show grants for dba@localhost; 查看其他 MySQL 用户权限:
. grant all on . to dba@localhost;赋权
. revoke all on . from dba@localhost;撤销权限
. grant select on testdb.* to dba@localhost with grant option; 如果想让授权的用户,也可以将这些权限 grant 给其他用户,需要选项 grant option
. mysqladmin -u root -p create RUNOOB 创建数据库
. mysqladmin -u root -p drop RUNOOB 删除数据库
. SELECT VERSION( )服务器版本信息
. SELECT DATABASE( )当前数据库名 (或者返回空)
. SELECT USER( )当前用户名
. SHOW STATUS服务器状态
. SHOW VARIABLES服务器配置变量
数据类型
正则表达式
mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';
mysql> SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';
事务
一般来说,事务是必须满足4个条件(ACID): Atomicity(原子性)、Consistency(稳定性)、Isolation(隔离性)、Durability(可靠性)
1、事务的原子性:一组事务,要么成功;要么撤回。
2、稳定性 :有非法数据(外键约束之类),事务撤回。
3、隔离性:事务独立运行。一个事务处理后的结果,影响了其他事务,那么其他事务会撤回。事务的100%隔离,需要牺牲速度。
4、可靠性:软、硬件崩溃后,InnoDB数据表驱动会利用日志文件重构修改。可靠性和高速度不可兼得, innodb_flush_log_at_trx_commit 选项 决定什么时候吧事务保存到日志里。
MYSQL 事务处理主要有两种方法:
1、用 BEGIN, ROLLBACK, COMMIT来实现
BEGIN 开始一个事务
ROLLBACK 事务回滚
COMMIT 事务确认
2、直接用 SET 来改变 MySQL 的自动提交模式:
SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交
复制表
CREATE TABLE targetTable LIKE sourceTable;
INSERT INTO targetTable SELECT * FROM sourceTable;
或者
show create table sourceTable; 得到创建语句,修改之后执行。