基本查询
select语句用于查询数据库和sql中的所有输出操作。
select c_u_name, email from cooya_users;
输出cooya_users表中所有行(或记录)的属性c_u_name和email的值。
如果需要所有属性,可以使用星号(*)的快捷方式。
select * from cooya_users;
select语句还可以输出不是数据库中的数据及可以用作简单的计算符。
select curtime();
select log(100)*4*pi();
where子句
where子句用作多数select查询的一部分,它局限于检索匹配条件的行。
select * from cooya_users where c_u_id 复杂一些的where子句使用布尔操作符and和or,以及函数。
select * from cooya_users where c_u_name = 'melon' and email='melon.cooya@gamil.com';
这将检索同时匹配两个条件的行。
select c_u_id from cooya_users where (c_u_name = 'melon' and city like 'shang%') or email='melon.cooya@gmail.com';
这将查找c_u_name为melon且city以s打头的行,或者电子邮件地址为melon.cooya@gmail.com的顾客。
where子句也是update和delect语句的常见组件。
update cooya_users set c_u_name = 'cooya1' where c_u_id = 2;
delete from cooya_users where c_u_id = 2;
对输出排序和归组
order by
select c_u_name from cooya_users where gender='female' and city='shanghai' order by c_u_name;
默认情况下,order by子句以升序(或asc)排序。要以降序排序,可以使用desc。
select * from cooya_users where city = 'shanghai' order by c_u_id desc;
group by
group by子句与order by不同,因为它不为输出排序数据。相反,它在查询过程中就对数据进行排序,目的是为了归组或聚合。
select city, count(*) from cooya_users group by city;
该查询输出已排序的一列城市,以及居住在每个城市的顾客数count。count(*) from的作用是对每一组的行数进行计数。 
dml(data manipulation language,数据操纵语言)包含了所有用于操纵数据的sql语句。下面4个语句形成dml语句集合:select、insert、delete和update。本节先描述后3个语句。
插入数据
方法一:
insert into cooya_users values (null, 'melon', 'female', 'melon.cooya@gmail.com', ' ');
方法二:
insert into cooya_users
set c_u_name = 'cooya',
gender = 'female',
email = 'melon.cooya@gmail.com';
删除数据
sql中的撤销和删除有很大区别。drop用于删除表或数据库,而delete用于删除数据。
delete from cooya_users;
删除cooya_users表中的所有数据,但是不删除表。相反,撤销表将删除数据和表。
带where子句的delete语句可以删除特定的行。
delete from cooya_users where c_u_id = 1;
更新数据
可以使用与insert语句类似的语法更新数据。
update cooya_users set email = lower(email);
update语句也常与where子句一起使用。
update cooya_users set city = 'shanghai' where c_u_id = 1;
创建数据库:
mysql> create database dbname;
为了处理数据库,命令解释器需要用户在能够发布sql语句之前使用数据库。在mysql解释器中可以发布以下命令:
mysql> use dbname
以下省略命令例子的mysql>提示符。
创建表格:
create table cooya_users (
c_u_id int(5) default '0' not null auto_increment,
c_u_name varchar(20) not null,
gender varchar(10) not null,
email varchar(30) not null,
city varchar(20),
primary key (c_u_id),
key names (c_u_name)
);
create table语句有3个部分: 
在create table语句后面是一个自由形式的表名称------在本例是cooya_users。 
开始圆括号后面是一个属性名、类型、和修饰字的列表。 
属性列表后面是一列键,也就是定义哪些属性满足主键的唯一性约束,以及哪些属性将为了快速访问而加以索引。
更改表和索引:
添加索引:
alter table cooya_users add index cities (city); 
删除索引:
alter table cooya_users drop index cities;
用show显示数据库结构
show databases
 列出 my sql dbms 可访问的数据库。
show tables
 显示已用 use 命令选定的数据库中的表。
show columns from tablename
 显示属性、属性的类型、键信息、是否允许null、默认值,以及表的其他信息。
 例如:
show columns from customer
 显示 customer 表的属性信息。describe table 产生相同的输出。
show index from tablename
 展示表中所有索引的详细信息,包括 primary key。
 例如:
show index from customer
 显示有两个索引,即主索引和 names 索引。
show status
 报告 mysql dbms 性能和统计的详细信息。
mysql的转义字符“/” 
mysql识别下列转义字符: 
/0 
一个ascii 0 (nul)字符。 
/n 
一个新行符。 
/t 
一个定位符。 
/r 
一个回车符。 
/b 
一个退格符。 
/' 
一个单引号(“'”)符。 
/  
一个双引号(“ ”)符。 
// 
一个反斜线(“/”)符。 
/% 
一个“%”符。它用于在正文中搜索“%”的文字实例,否则这里“%”将解释为一个通配符。 
/_ 一个“_”符。它用于在正文中搜索“_”的文字实例,否则这里“_”将解释为一个通配符。 
注意,如果你在某些正文环境中使用“/%”或“/%_”,这些将返回字符串“/%”和“/_”而不是“%”和“_”。 
★★ 
有几种方法在一个字符串内包括引号: 
1、必须转义的: 
一个字符串用单引号“'”来引用的,该字符串中的单引号“'”字符可以用“''”方式转义。 
一个字符串用双引号“ ”来引用的,该字符串中的“ ”字符可以用“  ”方式转义。 
同时你也可以继续使用一个转义字符“/”来转义 
2、可不转义的: 
一个字符串用双引号“ ”来引用的,该字符串中的单引号“'”不需要特殊对待而且不必被重复或转义。同理,一个字符串用单引号“'”来引用的,该字符串中的双引号“ ”不需要特殊对待而且不必被重复或转义。 
下面显示的select演示引号和转义如何工作: 
mysql > select 'hello', ' hello ', '  hello  ', 'hel''lo', '/'hello'; 
+----------+--------------+-------------------+----------+---------+ 
| hello | hello  |  hello   | hel'lo | 'hello | 
+----------+--------------+-------------------+----------+---------+ 
mysql > select hello , 'hello' , ''hello'' , hel  lo , / hello ; 
+----------+----------+-----------+------------+-----------+ 
| hello | 'hello' | ''hello'' | hel lo | hello | 
+---------+-----------+-----------+------------+-----------+ 
mysql > select this/nis/nfour/nlines ; 
+--------------------+ 
| this 
is 
four 
lines | 
+--------------------+ 
★★ 
如果你想要把二进制数据插入到一个blob列,下列字符必须由转义序列表示: 
nul 
ascii 0。你应该用'/0'(一个反斜线和一个ascii '0')表示它。 
/ 
ascii 92,反斜线。用'//'表示。 
' 
ascii 39,单引号。用“/'”表示。
ascii 34,双引号。用“/ ”表示
   
 
   