码迷,mamicode.com
首页 > 数据库 > 详细

PHP的MySQL扩张:MySQL数据库概述

时间:2015-09-16 14:11:32      阅读:233      评论:0      收藏:0      [点我收藏+]

标签:

资源:http://www.ido321.com/1023.html

一、SQL:结构化查询语言

        SQL(Structured Query Language)是高级的非过程化变成语言。专门用于查询和改动数据库的信息以及对数据库进行管理和维护的标准语言。SQL语言结构简单,功能强大,得到了众多DBMS的支持。

         SQL分为四个部分:

         数据定义语言(DDL):用于定义和管理数据对象。包含数据库、数据表等。

如create/drop/alter等

         数据操作语言(DML):操作数据库对象中包括的数据,如insert/update/delete等

         数据查询语言(DQL):查询数据库对象中包括的数据,并返回数据结果。如select

        数据控制语言(DCL):管理数据库对象,包含权限管理和数据更改。如grant/revoke/commit/rollback等

二、MySQL的常见操作

       1、连接和关闭:mysql –h 【server主机地址】-u username –p 用户password    quit和exit用于关闭连接

       2、创建用户和授权:GRANT 权限 ON 数据库.数据表 TO username@登陆主机 IDENTIFIED BY “password”

   1: //加入新用户。名为phper  passworddwqs,在不论什么主机登陆,对全部数据库拥有查询、插入、改动、删除权限
   2: //创建用户前,先以root用户登陆
   3: GRANT SELECT,INSERT,UPDATE,DELETE ON *.* TO phper@"%" IDENTIFIED BY "dwqs"
   4:  
   5: //仅仅对mydb数据库创建用户并授权
   6: GRANT SELECT,INSERT,UPDATE,DELETE ON mydb.* TO phper@localhost IDENTIFIED BY "dwqs"

       3、数据库操作

   1: //创建名为test的数据库
   2: create database [if not exists] test;
   3: //删除test
   4: drop database [if exists] test
   5: //显示数据库列表
   6: show databases
   7: //使用test数据库
   8: use test

       4、数据表操作

   1: //在test中创建一个表,表名是dwqs
   2: create table dwqs 
   3: <
   4: id int not null auto_increment,
   5: name varchar(20) not null default ‘‘,
   6: site varchar(20) not null default ‘www.ido321.com,
   7: email varchar(15) not null default ‘‘
   8: >
   1: //查看在test数据库的中表
   2: show tables
   3: //查看dwqs表的结构
   4: desc dwqs  或  description dwqs
   5: //删除dwqs表
   6: drop table dwqs

      5、数据表的内容管理

   1: //插入记录
   2: insert [into] 表名 [(字段名1),(字段名2),...,(字段名n)] values (‘值1‘,‘值2‘,...,‘值n‘)
   3: //更新记录
   4: update 表名 set 字段名1=表达式1[,字段名2=表达式2,...,字段名n=表达式n]
   5: [where 条件] [order by 字段] [limit 行数]
   6: //删除记录
   7: delete from 表名 [where 条件] [order by 字段] [limit 行数]
   8: //查询记录
   9: select [all|distinct]
  10: {*|table.*|[table.]field1[AS alias1],[table.]field2[AS alias2][,...]}
  11: from tablaname[,...][in externaldatabase]
  12: [where 条件][group by 字段][having 条件][order by 字段][limit 行数]

      说明:在查询中,distinct用于排除反复的数据,仅仅返回一个,默认是all。  as用于给列标记别名: 字段名 as ‘别名’,在查询的结果中,字段名以别名显示.in用于子查询,也能够使用like进行模糊查询,如 like ‘%php%’—>包括php字样的。%表示0个或随意个字符;like ‘dw_s’—>形如dwqs,dwrs等,_表示一个随意字符。group by是对查询结果分组。同一时候能够再select中嵌入SQL表达式或者函数,如count();

      6、改动表

   1: //这个"改动"主要改动表的结构。如加入字段、改动字段属性等
   2: alter table 表名 action
   3: //action的详细内容
   4: //加入新字段
   5: alter table 表名 add 字段名 描写叙述 [first|after 列名]
   6: alter table dwqs add qq int[14] not null  //为dwqs表加入一个qq字段,类型是整数,不为空
   7: //改动字段
   8: alter table 表名 change(modify) 列表 描写叙述
   9: alter table dwqs change qq qq varchar(15) default 0 //将qq字段的类型改为varchar,默认值是0
  10: alter table dwqs modify qq varchar(15) default 0 //将qq字段的类型改为varchar,默认值是0
  11: //改动表名
  12: alter table 旧表名 rename as 新表名

     说明:[first|after 列名]表名新字段的位置,first将字段插入第一列,after 列名将字段插入到指定列名之后。

未指定该值,默认在末尾加入。

                 modify和change的差别:change除了更改类型。还会更改列名,全部qq字段出现了两次,前一个是旧列名。后一个是新列名。而modify 没有改动列名的功能,全部qq仅仅出现了一次


下一篇:PHP的MySQL扩张:PHP通路MySQL频繁使用扩展函数

版权声明:本文博主原创文章,博客,未经同意不得转载。

PHP的MySQL扩张:MySQL数据库概述

标签:

原文地址:http://www.cnblogs.com/mengfanrong/p/4813030.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!