MySql学习(MariaDb)
资料
http://www.cnblogs.com/lyhabc/p/3691555.html
http://www.cnblogs.com/lyhabc/p/3691555.html
MariaDb
官网: https://mariadb.org/
安装地址: https://downloads.mariadb.org/mariadb/repositories
1. MySql .net Connector 在执行完命令后,关闭连接, 字符串中的 Password 会被清空。 设置带有 Password 的新字符串,连接字符串也不显示,但可以打开。
2. 我使用的是 HeidiSql客户端, 在使用 group_concat 函数时报错, 调试发现, group_concat 函数后面有一个空格,如果去除空格,则正确。不知道是客户端的原因,还是MySql的原因。
3. MySqlWorkbench 自定义快捷键: http://blog.csdn.net/stableboy/article/details/45887035
4. 国内镜像:
5. 连接: mysql -uroot -p1234
Windows安装
安装多份实例 , 拷贝多份 my.ini 目录。运行:
C:\Program Files\MySQL\MySQL Server 5.7\bin>mysqld --install MySql57_2 --defaults-file="C:\ProgramData\MySQL\MySQL Server 5.7_2\my.ini"
linux设置
查看状态: service mysql status
启动服务: service mysql start
对于mariadb新版: systemctl restart mariadb.service
转移数据库
http://blog.csdn.net/renfufei/article/details/17616549
查看配置
查找位置
which mysqld
查看配置
/usr/sbin/mysqld --verbose --help
找出配置文件地址:
/usr/sbin/mysqld --verbose --help | grep -A1 'Default options'
-A1 显示查找到该行以及该行之后的 after 1行。
大小写
设置MySql 区分大小写:http://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_lower_case_table_names
1)找到Mysql服务的配置文件,它在服务启动参数中: --defaults-file ,默认是:C:\ProgramData\MySQL\MySQL Server 5.6\my.ini
2)在my.ini,在 [mysqld] 下添加: lower_case_table_names=2
3)重启MySql服务。
0:存储为指定,大小写比较。 特殊情况:Windows,Mac 不能指定为0
1: 存储为小写。
2:存储为给定的名称,但使用小写比较。
CentOs7+mariadb10.0 路径: /etc/my.cnf.d/server.cnf
Ubuntu14+ mariadb10.1 路径: /etc/mysql/my.conf
设置远程连接
参考:http://www.cnblogs.com/24la/p/mariadb-remoting-access.html
在本地打开mysql,执行:
use mysql;
select * from user\G; #查看 user = 'root' 的记录。 \G 表示一行一段的展示,方便阅读。
GRANT ALL PRIVILEGES ON *.* to 'root'@'%' identified by '123456';
flush privileges;
如果上面的办法不行(影响行数为0),则可以修改配置文件。把 my.conf 里的 bind-address一行注释掉。
添加用户
程序执行时的用户及权限:
CREATE USER 'testuser'@'%' IDENTIFIED BY '1234';
GRANT USAGE ON *.* TO 'testuser'@'%';
GRANT SELECT, EXECUTE,CREATE, CREATE TEMPORARY TABLES, DELETE, INSERT, UPDATE, LOCK TABLES ON `test`.* TO 'testuser'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
SHOW GRANTS FOR 'testuser'@'%';
客户端管理者的权限:
CREATE USER 'testuser'@'%' IDENTIFIED BY '1234';
GRANT USAGE ON *.* TO 'testuser'@'%';
GRANT SELECT, EXECUTE, SHOW VIEW, ALTER, ALTER ROUTINE, CREATE, CREATE ROUTINE, CREATE TEMPORARY TABLES, CREATE VIEW, DELETE, DROP, EVENT, INDEX, INSERT, REFERENCES, TRIGGER, UPDATE, LOCK TABLES ON `test`.* TO 'testuser'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
SHOW GRANTS FOR 'testuser'@'%';
修改密码
先看用户在哪些主机上定义。
SELECT `user`, `host` FROM `mysql`.`user`;
SET PASSWORD FOR 'root'@'%' = PASSWORD('lwl417');
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('lwl417');
FLUSH PRIVILEGES;
编码
MySql编码最奇葩,标准编码: utf8mb4
collation: utf8mb4_general_ci
characterset: utf8mb4
非主键更新删除报错
http://jingyan.baidu.com/article/e5c39bf58ed69239d76033a4.html
执行:
SET SQL_SAFE_UPDATES = 0;
备份还原
我没有找到好的备份还原方法,MySql 这一点做的实在太差。
备份分为两部分: 一是备份脚本,包含表结构,函数,存储过程, 二是备份Insert数据.
默认情况下,导出数据库和 Insert 数据 .不包含存储过程和函数 .
一. 脚本:
mysqldump --host=server --user=root --password=1234 --no-data --routines DataBaseName > FileName
-d, --no-data 是不生成Insert语句
-R, --routines 是包含存储过程和函数
二. 仅 insert语句.
mysqldump -u root -t DataBaseName > FileName
-t, --no-create-info , 在默认的基础上,去除 create sql , 就剩 insert sql 了.
恢复:
mysql -uroot -p"db_password" -f dbname < backup.sql
-f 参数表示在导出过程中忽略出现的SQL错误
主从 数据同步设置
http://369369.blog.51cto.com/319630/790921/
快速复制数据库
mysqldump -h ${源服务器IP} -uroot -p123456 ${源数据库} --add-drop-table | mysql -h ${目标数据库IP} -u root -p123456 ${目标数据库}
如果要忽略某些表, mysql dump 时添加:
--ignore-table=database.table1 --ignore-table=database.table2
https://blog.csdn.net/whatlookingfor/article/details/51942566
语法
1.函数模板:
delimiter $$ CREATE function CompareStr (FirstVal varchar(1000),SecondVal varchar(1000) )
returns int
begin if ( FirstVal is null ) then
return -1 ;
end if; if ( SecondVal is null ) then
return -1 ;
end if; set FirstVal = lower(rtrim(ltrim(FirstVal)));
set SecondVal = lower(rtrim(ltrim(SecondVal))); if (FirstVal = SecondVal ) then
return 0;
else
return 1;
end if; end
$$
DELIMITER ;
If ( condition) then statement elseif ( condition ) then statement end if ; 最后的 ; 一定要有。
2.存储过程模板
DELIMITER $$
CREATE PROCEDURE `S_CreateVarTable`(VarTable varchar(50) , VarName varchar(50), VarValue varchar(9) )
label_pro:
begin set @CorpTable = replace(VarTable , concat( '{' , VarName ,'}' ), concat('{' , VarValue , '}')) ; if exists (select 1 from information_schema.Tables where table_schema= database() and table_Name = @CorpTable ) then
leave label_pro;
end if; set @sql = N'
create table `{InstanceTable}` (
select *
from `{VarTable}`
limit 0,0 );
'; set @sql = replace(@sql,'{VarTable}', VarTable) ;
set @sql = replace(@sql,'{InstanceTable}', @CorpTable) ; prepare smt from @sql ;
execute smt ; end$$
DELIMITER ;
3. 修改自增种子值: alter table users AUTO_INCREMENT=10000;
4. 计算列:
https://mariadb.com/kb/en/mariadb/virtual-computed-columns/
http://www.linuxidc.com/Linux/2016-02/128066.htm
在创建列类型后面添加: GENERATED ALWAYS AS ($表达式$)
如果是计算列, MySql 有两种方式:Virtual 和 Stored。 MariaDb 称为: Virtual 和 Presistent
5. 血的教训. 分页必须要有 order by
诡异的情况: group by broker_id , dealer_id limit #{take} , #{skip} 获取所有的数据时, 出现重复数据.
MySql学习(MariaDb)的更多相关文章
- MySQL学习分享--Thread pool实现
基于<MySQL学习分享--Thread pool>对Thread pool架构设计的详细了解,本文主要对Thread pool的实现进行分析,并根据Mariadb和Percona提供的开 ...
- MySQL学习基础
MySQL是被Sun公司收购了,所以也有热咖啡图标,不过MySQL的作者后来又做了一个MariaDB,小海豚图标,也很好用. MySQL学习: <MySQL网络数据库设计与开发>(电子工业 ...
- 我的MYSQL学习心得(一) 简单语法
我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- 我的MYSQL学习心得(二) 数据类型宽度
我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- 我的MYSQL学习心得(三) 查看字段长度
我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- 我的MYSQL学习心得(四) 数据类型
我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(五) 运 ...
- 我的MYSQL学习心得(五) 运算符
我的MYSQL学习心得(五) 运算符 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...
- 我的MYSQL学习心得(六) 函数
我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...
- 我的MYSQL学习心得(七) 查询
我的MYSQL学习心得(七) 查询 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...
- 我的MYSQL学习心得(八) 插入 更新 删除
我的MYSQL学习心得(八) 插入 更新 删除 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得( ...
随机推荐
- MySQL数据库设置远程访问权限方法总结
1,设置访问单个数据库权限 mysql>grant all privileges on test.* to 'root'@'%'; 说明:设置用户名为root,密码为空,可访问数据库test 2 ...
- mysql备份文件注释乱码处理工具
我们有时候需要做mysql数据库的注释,可是备份出来的是乱码,怎么办呢? 本工具软件来帮你的忙. 将GBK库备份后的文本文件中夹带的UTF8乱码转换为GBK编码,就不再乱码了. http://down ...
- css鼠标手型cursor中hand与pointer
css鼠标手型cursor中hand与pointer Example:CSS鼠标手型效果 <a href="#" style="cursor:hand"& ...
- CentOS 6.5 x86_64系统手动释放内存
1.查询当前内存使用情况和释放缓存的参数 redismaster 10:29:24 [~] [root] free -m total used free shared buffers cachedMe ...
- .NET J2EE APP全局会话架构运用场景
.NET J2EE APP全局会话架构运用场景, 全局会话运用拓扑图代码核心架构为.NET架构开发C#语言为主代码架构分为全局会话中心.ASP.NET会话节点..NET会话节点针对WCF服务器与APP ...
- Vim自动补全神器–YouCompleteMe
YouCompleteMe的特别之处 基于语义补全 总所周知,Vim是一款文本编辑器.也就是说,其最基础的工作就是编辑文本,而不管该文本的内容是什么.在Vim被程序员所使用后,其慢慢的被肩负了与IDE ...
- jackson json转list
今天项目中用到了jackson,经理说效率高一些,所以就开始用起来,一开始json转对象,对象转json还是很简单的,但也还是有一些问题,后来加了一点配置属性就没有报错了 ObjectMapper m ...
- #笔记# CSS工作流
目录 明确代码规范 CSS Reset 关于前缀 浮动闭合 CSS的前处理器(Preprocessor)和后处理器(Postprocessor) 明确代码规范 目的是确保跨平台协作多人开发的代码显示界 ...
- C#is运算符的作用
is运算符的含义:检查对象是不是给定类型,或者是否可以转换为给定类型,如果是,这个运算符就返回True. is运算符的语法:<operand> is <type> 这个表达式的 ...
- Firebird数据库系统的开发团队
下载Firebird3的发布文档,上面列出了开发团队,仔细看了看,原来俄罗斯人是主导(内核开发),法国人.智利人.巴西人.日本人.荷兰人.捷克人都有.共17人,3人全职. able 13.1. Fir ...