mysql学习笔记

安装

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; 得到创建语句,修改之后执行。
posted @ 2017-11-28 10:56  abcyrf  阅读(190)  评论(0编辑  收藏  举报