mysql学习笔记_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服务器配置变量

数据类型

fe9a1a7ec91ef02861cec18a434fbf75.png

ae9f6f0058b39e367069410d9309d356.png

fefd9ea16642b4e7a2366813afe25a84.png

正则表达式

mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';

mysql> SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';

09dccc959aafd4460924dfd3fa3af08a.png

事务

一般来说,事务是必须满足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; 得到创建语句,修改之后执行。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值