【数据库开发】在Windows上和Linux上配置MySQL的过程
【数据库开发】在Windows上和Linux上配置MySQL的过程
标签(空格分隔): 【编程开发】
首先是在Windows上尝试用QT进行MySQL数据库开发,结果总出现driver不能load的错误,一直没有改过来。后又直接尝试在Linux下进行MySQL开发,直接安装了三个包就可以使用了。下面记录这些过程。
在Linux下配置MySQL的过程
首先是安装mysql,以ubuntu为例:
sudo apt-get install mysql-server mysql-client
//安装过程中会让你输入root密码,比如:123456
安装完成后,使用,我们就可以在命令行运行mysql了:
mysql -u root -p
//Enter password:123456
进入mysql了,可以输入各种命令了:
mysql> create database testdb;//创建一个数据库
mysql> use testdb;//切换到该数据库
mysql> create table student (sid int primary key not null, name varchar(20));//创建一个表
mysql> insert into student values (2010110, 'shuguang');//插入一条记录
mysql> select * from student;//查询
mysql> delete form student where name = 'shuguang';//删除一条记录
mysql> update student set name = 'chengshuguang' where name = 'shuguang';//更新一条记录
mysql> drop table student;//删除表
mysql> drop database testdb;//删除数据库
//显示
mysql> show databases;//显示所有数据库列表
mysql> show tables;//显示一个数据库中的所有表
mysql> desc/describe student;//查看student表的结构
mysql> show table status;//显示table的各种配置信息,比如Engine是MyISAM(默认)还是InnoDB(支持transaction)
//由于鄙人开发过程中要用到transaction来保证数据的一致性,所以需要把Engine切换到InnoDB,其实很简单,如下:
mysql> alter table student ENGINE = InnoDB;
关于引擎的切换要单独拿出来,主要是便于我以后查看:
mysql> alter table student ENGINE = InnoDB;
切换到InnoDB之后,就可以用事务(transaction)了
begin transaction;
...
do anything...
...
commit;//没有出错则提交
rollback;//出错,那么就rollback,这个功能就是我需要
然后就是应用mysql开发啦:
你还需要安装一个开发包:libmysql++-dev
sudo apt-get install libmysql++-dev
到这一步,一切准备就绪,只差写代码啦:
#include<stdio.h>
#include<mysql/mysql.h>
int main()
{
MYSQL mysql;
mysql_init(&mysql);
if(!mysql_real_connect(&mysql,"localhost","root","110315","testdb",0,NULL,0)){
fprintf(stderr,"Failedtoconnecttodatabase:Error:%s\\n",mysql_error(&mysql));
}
else{
printf("database connect..\n");
}
mysql_close(&mysql);
return 0;
}
编译的时候要注意加上-lmysqlclient
g++ testmysql.cpp -g -Wall -lmysqlclient -o testmysql
在Windows下配置MySQL的过程
首先在下面的连接中找到了一个community版本的SQL,GPL。
是一个压缩包,解压过后放在了D盘路径,进入到对应的:
D:\mysql_5_7_17_winx64\bin
里面实际上就对应Linux下的各种命令的可执行文件;
在第一次配置的过程中遇到了各种问题,总之就是连接不上,都进不去mysql。
下面是正确的部署过程:
mysqld --initialize-insecure
只输mysqld –initialize 生成随机密码进不去的,输入mysqld –initialize-insecure生成无密码的用户
上面的作用是初始化mysql环境,生成了对应的data路径:
D:\mysql_5_7_17_winx64\data
之后安装mysqld服务:
mysqld –install #安装服务
然后可以开启服务:
net start mysql
这样才会开启服务,然后使用mysql进行登陆
mysql -u root
不需要输入密码,因为上面初始化的时候设置了root没有密码,进入后可以修改密码:
方法1: 用SET PASSWORD命令
MySQL -u root
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass');
方法2:用mysqladmin
mysqladmin -u root password "newpass"
如果root已经设置过密码,采用如下方法
mysqladmin -u root password oldpass "newpass"
方法3: 用UPDATE直接编辑user表
mysql -u root
mysql> use mysql;
mysql> UPDATE user SET Password = PASSWORD('newpass') WHERE user = 'root';
mysql> FLUSH PRIVILEGES;
在丢失root密码的时候,可以这样
mysqld_safe --skip-grant-tables&
mysql -u root mysql
mysql> UPDATE user SET password=PASSWORD("new password") WHERE user='root';
mysql> FLUSH PRIVILEGES;
2016-12-20 20:34
张朋艺 pyZhangBIT2010@126.com
【数据库开发】在Windows上和Linux上配置MySQL的过程的更多相关文章
- 在linux中配置mysql的过程
以华为企业云中的CentOS 7 为例. 1. 首先要安装相应的包,这个使用各种linux发行版的包管理工具就行,不再赘述.有一点需要注意,现在许多linux发行版将mariadb作为MySQL的默认 ...
- Gradle在Windows环境与Linux上配置有哪些不同?
我的开发环境:Windows + Android Studio + Gradle 2.8 all + Jenkins 公司CI 服务器环境: Linux + Gradle 2.10 bin + Jen ...
- linux下配置mysql默认编码utf8
linux下配置mysql默认编码utf8 下面是需要在对应地方加入的配置 [client] default-character-set=utf8 [mysqld] character-set-ser ...
- Windows软件在Linux上的等价/替代/模仿软件列表 (抄一个)
Last update: 16.07.2003, 31.01.2005, 27.05.2005 您可在以下网站发现本列表最新版:http://www.linuxrsp.ru/win-lin-soft/ ...
- Mantis 从Windows 迁移到Linux上
1. 导出windows manits的mysql数据库文件, 在cmd运行:mysqldump -uroot -p3edc$RFV bugtracker > C:/mantis.sql; 2. ...
- 在windows 7 和linux上安装xlwt和xlrd
在windows 7上安装xlwt xlrd xlwt是开源社区编写的python库,需要单独安装,下载地址https://pypi.python.org/pypi/xlwt 目前xlwt最新的版本是 ...
- windows下数据库文件使用脚本同步到linux下的mysql数据库中
1.背景 windows server 2008 下 每天会有 *.sql数据文件 需要上传到linux 中的mysql数据库中 而运维人员是在 windows server 下使用 xshell 连 ...
- Win10上使用Linux Subsystem配置cuckoo sandbox
原文连接:https://www.trustwave.com/Resources/SpiderLabs-Blog/Cuckoo--Linux-Subsystem--Some-Love-for-Wind ...
- octave在win上和linux上配置syms
octave是类似matlab的一个科学计算工具集.需要用到积分.微分.求导的时候,需要连接python3的sympy. windows上先安装好python3,然后pip安装Sympy.具体过程: ...
随机推荐
- Learning Spark (Python版) 学习笔记(一)----RDD 基本概念与命令
<Learning Spark>这本书算是Spark入门的必读书了,中文版是<Spark快速大数据分析>,不过豆瓣书评很有意思的是,英文原版评分7.4,评论都说入门而已深入不足 ...
- Linux 理解Linux的memory overcommit 与 OOM Killer
Memory Overcommit的意思是操作系统承诺给进程的内存大小超过了实际可用的内存.一个保守的操作系统不会允许memory overcommit,有多少就分配多少,再申请就没有了,这其实有些浪 ...
- 代码 | 自适应大邻域搜索系列之(7) - 局部搜索LocalSearch的代码解析
前言 好了小伙伴们我们又见面了,咳咳没错还是我.不知道你萌接连被这么多篇代码文章刷屏是什么感受,不过,酸爽归酸爽.今天咱们依然讲代码哈~不过今天讲的依然很简单,关于局部搜索LocalSearch的代码 ...
- intelij idea 2018 license server
http://www.cnblogs.com/jin-zhe/p/9267912.html
- Vue的学习--遇到的一些问题和解决方法(二)
1.关于图片路径问题 1.关于图片路径问题 在.vue的html中可以直接使用相对路径,但是从浏览器后台可以看出,最后路径是自行做了替换的.如果需要在js文件中使用,则需要自己使用require进行替 ...
- shell 脚本同时对远程多台机器执行命令
脚本1:需要机器之间免密 ssh-copy-id [-i [identity_file]] [user@]machine #!/bin/bash # ------------------------- ...
- Tcl模块化
Proc 过程名 参数列表 过程体 示例代码(斐波那契数列): proc fib {num} { if {$num<=2} {return 1} return [expr [fib [expr ...
- GO 包相关
1 包编译,eg: 引用pkgtest包 pkgtest包没有任何编译,项目直接导入引用,项目编译时实际是会编译pkgtest并在pkg\windows_386下生成pkgtest.a文件 再编译项目 ...
- Java判断整数溢出
开题报告第一版写完发给老师了,熬了两周终于搞出来了,等着被怼了之后再改吧.晚上选了Leetcode一道简单的题,整数反转,就是将一个int类型的数反转.原本确实很简单,最后出现个问题有意思--整数溢出 ...
- sqlserver 触发器实例
实例1:update USE [数据库名称]GO/****** Object: Trigger [dbo].[触发器名称] Script Date: 05/08/2014 12:40:25 ***** ...