mysql学习笔记

来源:互联网 发布:合同管理系统源码 编辑:程序博客网 时间:2024/05/05 07:48
 
1、安装环境:
     Windows XP
     Mysql 4.0.17 从 http://www.mysql.com下载
     EMS Mysql Query 1.6.0.1
     本机IP:172.5.1.183
2、安装Mysql,采用默认安装即可
   目录选择在c:mysql,不要修改默认目录
3、启动Mysql
   安装为服务:c:mysqlbinmysqld --install
   启动Mysql: net start mysql
   停止Mysql: net stop mysql
4、系统创建的数据库有mysql,test
   mysql保存系统数据
   test数据库用来测试
5、默认登陆方式
   在本机
     c:mysqlbinmysql -uroot
     c:mysqlbinmysql
   远程
     mysql -h 172.5.1.183 -uroot
  
   这些是在mysql.user表中,系统默认存在4条数据
        use mysql
        select host,user,password from user;
        +-----------+------+----------+
 | host      | user | password |
 +-----------+------+----------+
 | localhost | root |          |
 | %         | root |          |
 | localhost |      |          |
 | %         |      |          |
 +-----------+------+----------+
  
   这些数据代表的意义:
     用户名为root,密码为空的用户可以从本机和任何远程主机登陆
     任何用户名,密码为空的用户可以从本机登陆
     用户名为空,密码为空的用户不可以从远程登陆 (user中后面的字段为N,所以无法登陆)
   修改root密码
     mysql -uroot
     use mysql
     update user set password=PASSWORD("root") where user='root' and host='localhost'
   下次就需要用mysql -uroot -proot才可以登陆
   在远程或本机可以使用 mysql -h 172.5.1.183 -uroot 登陆,这个根据第二行的策略确定
   权限修改生效:
      1)net stop mysql
        net start mysql
      2)c:mysqlbinmysqladmin flush-privileges
      3)登陆mysql后,用flush privileges语句
6、创建数据库staffer
   create database staffer;
7、下面的语句在mysql环境在执行
   显示用户拥有权限的数据库       show databases;
   切换到staffer数据库       use staffer;
   显示当前数据库中有权限的表 show tables;
   显示表staffer的结构   desc staffer;
8、创建测试环境
   1)创建数据库staffer
     mysql> create database staffer
   2)创建表staffer,department,position,depart_pos
     create table s_position
     (
         id int not null auto_increment,
         name varchar(20) not null default '经理', #设定默认值
         description varchar(100),
         primary key PK_positon (id)  #设定主键
     );    
     create table department
     (
         id int not null auto_increment,
         name varchar(20) not null default '系统部', #设定默认值
         description varchar(100),
         primary key PK_department (id)  #设定主键
     );
     create table depart_pos
     (
         department_id int not null,
         position_id int not null,
         primary key PK_depart_pos (department_id,position_id)  #设定复和主键
     );
     create table staffer
     (
         id int not null auto_increment primary key,  #设定主键
         name varchar(20) not null default '无名氏',  #设定默认值
         department_id int not null,
         position_id int not null,
         unique (department_id,position_id)  #设定唯一值
     );
   3)删除
     mysql>
        drop table depart_pos;
        drop table department;
        drop table s_position;
        drop table staffer;
        drop database staffer;
9、修改结构
   mysql>
   #表position增加列test
   alter table position add(test char(10));
   #表position修改列test
   alter table position modify test char(20) not null;
   #表position修改列test默认值
   alter table position alter test set default 'system';
   #表position去掉test默认值
   alter table position alter test drop default;
   #表position去掉列test
   alter table position drop column test;
   #表depart_pos删除主键
   alter table depart_pos drop primary key;
   #表depart_pos增加主键
   alter table depart_pos add primary key PK_depart_pos (department_id,position_id);
10、操作数据
   #插入表department
   insert into department(name,description) values('系统部','系统部');
   insert into department(name,description) values('公关部','公关部');
   insert into department(name,description) values('客服部','客服部');
   insert into department(name,description) values('财务部','财务部');
   insert into department(name,description) values('测试部','测试部');
   #插入表s_position
   insert into s_position(name,description) values('总监','总监');
   insert into s_position(name,description) values('经理','经理');
   insert into s_position(name,description) values('普通员工','普通员工');
   #插入表depart_pos
   insert into depart_pos(department_id,position_id)
   select a.id department_id,b.id postion_id
   from department a,s_position b;
   #插入表staffer
   insert into staffer(name,department_id,position_id) values('陈达治',1,1);
   insert into staffer(name,department_id,position_id) values('李文宾',1,2);
   insert into staffer(name,department_id,position_id) values('马佳',1,3);
   insert into staffer(name,department_id,position_id) values('亢志强',5,1);
   insert into staffer(name,department_id,position_id) values('杨玉茹',4,1);
11、查询及删除操作
   #显示系统部的人员和职位
   select a.name,b.name department_name,c.name position_name
   from staffer a,department b,s_position c
   where a.department_id=b.id and a.position_id=c.id and b.name='系统部';
   #显示系统部的人数
   select count(*) from staffer a,department b
   where a.department_id=b.id and b.name='系统部'
   #显示各部门的人数
   select count(*) cou,b.name
   from staffer a,department b
   where a.department_id=b.id
   group by b.name;
   #删除客服部
   delete from department where name='客服部';
   #将财务部修改为财务一部
   update department set name='财务一部' where name='财务部';
12、备份和恢复
    备份数据库staffer
     c:mysqlbinmysqldump -uroot -proot staffer>e:staffer.sql
     得到的staffer.sql是一个sql脚本,不包括建库的语句,所以你需要手工
     创建数据库才可以导入
    恢复数据库staffer,需要创建一个空库staffer
     c:mysqlbinmysql -uroot -proot staffer<staffer.sql
     如果不希望后来手工创建staffer,可以
     c:mysqlbinmysqldump -uroot -proot --databases staffer>e:staffer.sql
     mysql -uroot -proot >e:staffer.sql
     但这样的话系统种就不能存在staffer库,且无法导入其他名字的数据库, 当然你可以手工修改staffer.sql文件
13、从文本向数据库导入数据
    1)使用工具c:mysqlbinmysqlimport
    这个工具的作用是将文件导入到和去掉文件扩展名名字相同的表里,如
    staffer.txt,staffer都是导入到staffer表中
    常用选项及功能如下
 -d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息
 -f or --force 不管是否遇到错误,mysqlimport将强制继续插入数据
 -i or --ignore mysqlimport跳过或者忽略那些有相同唯一
 关键字的行, 导入文件中的数据将被忽略。
 -l or -lock-tables 数据被插入之前锁住表,这样就防止了,
 你在更新数据库时,用户的查询和更新受到影响。
 -r or -replace 这个选项与-i选项的作用相反;此选项将替代表中有相同唯一关键字的记录。
 --fields-enclosed- by= char
 指定文本文件中数据的记录时以什么括起的, 很多情况下 数据以双引号括起。 默认的情况下数据是没有被字符括起的。
 --fields-terminated- by=char
 指定各个数据的值之间的分隔符,在句号分隔的文件中, 分隔符是句号。您可以用此选项指定数据之间的分隔符。
 默认的分隔符是跳格符(Tab)
 --lines-terminated- by=str
 此选项指定文本文件中行与行之间数据的分隔字符串或者字符。 默认的情况下mysqlimport以newline为行分隔符。
 您可以选择用一个字符串来替代一个单个的字符:
 一个新行或者一个回车。
 mysqlimport命令常用的选项还有-v 显示版本(version),
            -p 提示输入密码(password)等。
   这个工具有个问题,无法忽略某些列,这样对我们的数据导入有很大的麻烦,虽然可以手工设置这个字段,但会出现莫名其妙的结果,我们做一个简单的示例
   我们定义如下的depart_no.txt,保存在e盘,间隔为制表符t
 10 10
 11 11
 12 24 
 执行如下命令
    c:mysqlbinmysqlimport -uroot -proot staffer e:depart_pos.txt
    在这里没有使用列的包围符号,分割采用默认的t,因为采用别的符号会有问题,不知道是不是windows的原因
    2)Load Data INFILE file_name into table_name(column1_name,column2_name)
      这个命令在mysql>提示符下使用,优点是可以指定列导入,示例如下
      c:mysqlbinmysql -uroot -proot staffer
      mysql>load data infile "e:/depart_no.txt" into depart_no(department_id,position_id);
   
    这两个工具在Windows下使用都有问题,不知道是Windows的原因还是中文的问题, 而且不指定的列它产生了空值,这显然不是我们想要的,所以谨慎使用这些工具
有很多朋友虽然安装好了mysql但却不知如何使用它。在这篇文章中我们就从连接MYSQL、修改密码、增加用户等方面来学习一些MYSQL的常用命令。

一、连接MYSQL。
格式: mysql -h主机地址 -u用户名 -p用户密码
1、例1:连接到本机上的MYSQL。
首先在打开DOS窗口,然后进入目录 mysqlbin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是:mysql>
2、例2:连接到远程主机上的MYSQL。假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
mysql -h110.110.110.110 -uroot -pabcd123
(注:u与root可以不用加空格,其它也一样)
3、退出MYSQL命令: exit (回车)
二、修改密码。
格式:mysqladmin -u用户名 -p旧密码 password 新密码
1、例1:给root加个密码ab12。首先在DOS下进入目录mysqlbin,然后键入以下命令
mysqladmin -uroot -password ab12
注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
2、例2:再将root的密码改为djg345。
mysqladmin -uroot -pab12 password djg345
三、增加新用户。(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MYSQL,然后键入以下命令:
grant select,insert,update,delete on *.* to test1@"%" Identified by "abc";
但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台计算机上登录你的mysql数据库并对你的资料可以为所欲为了,解决办法见例2。
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
grant select,insert,update,delete on mydb.* to test2@localhost identified by "abc";
如果你不想test2有密码,可以再打一个命令将密码消掉。
grant select,insert,update,delete on mydb.* to test2@localhost identified by "";


(下篇)

在上篇我们讲了登录、增加用户、密码更改等问题。下篇我们来看看MYSQL中有关数据库方面的操作。注意:你必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下进行的,而且每个命令以分号结束。

一、操作技巧
1、如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK。
2、你可以使用光标上下键调出以前的命令。但以前我用过的一个MYSQL旧版本不支持。我现在用的是mysql-3.23.27-beta-win。

二、显示命令
1、显示数据库列表。
show databases;
刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
2、显示库中的资料表:
use mysql; //打开库,学过FOXBASE的一定不会陌生吧
show tables;
3、显示资料表的结构:
describe 表名;
4、建库:
create database 库名;
5、建表:
use 库名;
create table 表名 (字段设定列表);
6、删库和删表:
drop database 库名;
drop table 表名;
7、将表中记录清空:
delete from 表名;
8、显示表中的记录:
select * from 表名;

三、一个建库和建表以及插入数据的实例
drop database if exists school; //如果存在SCHOOL则删除
create database school; //建立库SCHOOL
use school; //打开库SCHOOL
create table teacher //建立表TEACHER
(
id int(3) auto_increment not null primary key,
name char(10) not null,
address varchar(50) default 深圳,
year date
); //建表结束
//以下为插入字段
insert into teacher valuess(,glchengang,深圳一中,1976-10-10);
insert into teacher valuess(,jack,深圳一中,1975-12-23);

注:在建表中(1)将ID设为长度为3的数字字段:int(3)并让它每个记录自动加一:auto_increment并不能为空:not null而且让他成为主字段primary key(2)将NAME设为长度为10的字符字段(3)将ADDRESS设为长度50的字符字段,而且缺省值为深圳。varchar和char有什么区别呢,只有等以后的文章再说了。 (4)将YEAR设为日期字段。
如果你在mysql提示符键入上面的命令也可以,但不方便调试。你可以将以上命令原样写入一个文本文件中假设为school.sql,然后复制到c:下,并在DOS状态进入目录mysqlbin,然后键入以下命令:
mysql -uroot -p密码 < c:school.sql
如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。

四、将文本资料转到数据库中
1、文本资料应符合的格式:字段资料之间用tab键隔开,null值用n来代替.
例:
3 rose 深圳二中 1976-10-10
4 mike 深圳一中 1975-12-23
2、数据传入命令 load data local infile "文件名" into table 表名;
注意:你最好将文件复制到mysqlbin目录下,并且要先用use命令打表所在的库 。

五、备份数据库:(命令在DOS的mysqlbin目录下执行)
mysqldump --opt school>school.bbb
注释:将数据库school备份到school.bbb文件,school.bbb是一个文本文件,文件名任取,打开看看你会有新发现。

后记:其实MYSQL的对数据库的操作与其它的SQL类数据库大同小异,您最好找本将SQL的书看看。我在这里只介绍一些基本的,其实我也就只懂这些了,呵呵。最好的MYSQL教程还是“晏子“译的“MYSQL中文参考手册“不仅免费每个相关网站都有下载,而且它是最权威的。可惜不是象"PHP4中文手册"那样是chm的格式,在查找函数命令的时候不太方便。
 
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 伺服电机丢脉冲怎么办 工控机西门子系统死机怎么办 iPad屏幕被磁化怎么办 win10鼠标不反应怎么办 快把游戏打不开怎么办 消防退出现役士兵怎么办 武警退出现役士兵怎么办 c盘空间不够怎么办 解压文件被破坏怎么办 exe被拒绝访问怎么办 游戏文件删除了怎么办? 战地一打不开怎么办 迅雷怎么下载不动怎么办 电脑带不动游戏怎么办 sap wm自动上架怎么办 战地1停止运行怎么办 c9pro检测到潮湿怎么办 战地1卡顿怎么办 战地1停止工作怎么办 大写锁定shift解除怎么办 游戏突然掉帧怎么办 oppo应用商店打不开怎么办 ps4战地1校园网怎么办 战地4延迟高怎么办 红米手机打不开怎么办 台式电脑网页打不开怎么办 电脑网页很多都打不开怎么办 qq发送不了位置怎么办 qq无法找到入口怎么办 玩游戏总是掉怎么办 ipad所有按键失灵怎么办 手机启动器停止运行怎么办 安卓版泰拉瑞亚联机失去连接怎么办 吃鸡安装不了怎么办 obb文件丢失了怎么办 dnf登录闪退怎么办 泰拉瑞亚地图找不到备份怎么办 服务器没远程管理卡怎么办 tplink上不了网怎么办 键盘端口坏了怎么办 小米路由dns错误怎么办