mysql 的一些基本应用
[b]基本查询[color=orange]SELECT[/color][/b]语句用于查询[u][b][color=#810081]数据库[/color][/b][/u]和SQL中的所有输出操作。
[color=orange][b]SELECT[/b][/color] c_u_name, email [color=orange][b]FROM[/b][/color] cooya_users;
输出cooya_users表中所有行(或记录)的属性c_u_name和email的值。
如果需要所有属性,可以使用星号(*)的快捷方式。
[color=orange][b]SELECT[/b][/color] * FROM cooya_users;
[color=orange][b]SELECT[/b][/color]语句还可以输出不是数据库中的数据及可以用作简单的计算符。
[color=orange][b]SELECT[/b][/color] curtime();
[color=orange][b]SELECT[/b][/color] log(100)*4*pi();
[b][color=orange]WHERE[/color]子句[/b]
[color=orange][b]WHERE[/b][/color]子句用作多数SELECT查询的一部分,它局限于检索匹配条件的行。
[color=orange][b]SELECT[/b][/color] * [color=orange][b]FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] c_u_id <= 3;
复杂一些的[color=orange][b]WHERE[/b][/color]子句使用布尔操作符[color=orange][b]AND[/b][/color]和[color=orange][b]OR[/b][/color],以及函数。
[color=orange][b]SELECT[/b][/color] * [color=orange][b]FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] c_u_name = 'melon' [color=orange][b]AND[/b][/color] email='melon.cooya@gamil.com';
这将检索同时匹配两个条件的行。
[color=orange][b]SELECT[/b][/color] c_u_id [color=orange][b]FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] (c_u_name = 'melon' [color=orange][b]AND[/b][/color] city [color=orange][b]LIKE[/b][/color] 'shang%') [color=orange][b]OR[/b][/color] email='melon.cooya@gmail.com';
这将查找c_u_name为melon且city以s打头的行,或者电子邮件地址为[email]melon.cooya@gmail.com[/email]的顾客。
[color=orange][b]WHERE[/b][/color]子句也是[color=orange][b]UPDATE[/b][/color]和[color=orange][b]DELECT[/b][/color]语句的常见组件。
[color=orange][b]UPDATE[/b][/color] cooya_users [color=orange][b]SET[/b][/color] c_u_name = 'cooya1' [color=orange][b]WHERE[/b][/color] c_u_id = 2;
[color=orange][b]DELETE FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] c_u_id = 2;
[b]对输出排序和归组[/b]
[color=orange][b]ORDER BY[/b][/color]
[color=orange][b]SELECT[/b][/color] c_u_name [color=orange][b]FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] gender='female' [color=orange][b]AND[/b][/color] city='shanghai' [color=orange][b]ORDER BY[/b][/color] c_u_name;
默认情况下,[color=orange][b]ORDER BY[/b][/color]子句以升序(或[color=orange][b]ASC[/b][/color])排序。要以降序排序,可以使用[color=orange][b]DESC[/b][/color]。
[color=orange][b]SELECT[/b][/color] * [color=orange][b]FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] city = 'shanghai' [color=orange][b]ORDER BY[/b][/color] c_u_id [color=orange][b]DESC[/b][/color];
[color=orange][b]GROUP BY[/b][/color]
GROUP BY子句与ORDER BY不同,因为它不为输出排序数据。相反,它在查询过程中就对数据进行排序,目的是为了归组或聚合。
[color=orange][b]SELECT[/b][/color] city, [color=orange][b]COUNT(*) FROM[/b][/color] cooya_users [color=orange][b]GROUP BY[/b][/color] city;
该查询输出已排序的一列城市,以及居住在每个城市的顾客数COUNT。[color=orange][b]COUNT(*) FROM[/b][/color]的作用是对每一组的行数进行计数。
DML(Data Manipulation Language,数据操纵语言)包含了所有用于操纵数据的SQL语句。下面4个语句形成DML语句集合:[color=orange][b]SELECT[/b][/color]、[color=orange][b]INSERT[/b][/color]、[color=orange][b]DELETE[/b][/color]和[color=orange][b]UPDATE[/b][/color]。本节先描述后3个语句。
[b]插入数据[/b]
方法一:
[color=orange][b]INSERT INTO[/b][/color] cooya_users [color=orange][b]VALUES[/b][/color] (NULL, 'melon', 'female', 'melon.cooya@gmail.com', ' ');
方法二:
[color=orange][b]INSERT INTO[/b][/color] cooya_users
[color=orange][b]SET[/b][/color] c_u_name = 'cooya',
gender = 'female',
email = 'melon.cooya@gmail.com';
[b]删除数据[/b]
SQL中的撤销和删除有很大区别。[color=orange][b]DROP[/b][/color]用于删除表或数据库,而[color=orange][b]DELETE[/b][/color]用于删除数据。
[color=orange][b]DELETE FROM[/b][/color] cooya_users;
删除cooya_users表中的所有数据,但是不删除表。相反,撤销表将删除数据和表。
带[color=orange][b]WHERE[/b][/color]子句的DELETE语句可以删除特定的行。
[color=orange][b]DELETE FROM[/b][/color] cooya_users [color=orange][b]WHERE[/b][/color] c_u_id = 1;
[b]更新数据[/b]
可以使用与[color=orange][b]INSERT[/b][/color]语句类似的语法更新数据。
[color=orange][b]UPDATE[/b][/color] cooya_users [color=orange][b]SET[/b][/color] email = lower(email);
[color=orange][b]UPDATE[/b][/color]语句也常与[color=orange][b]WHERE[/b][/color]子句一起使用。
[color=orange][b]UPDATE[/b][/color] cooya_users [color=orange][b]SET[/b][/color] city = 'shanghai' [color=orange][b]WHERE[/b][/color] c_u_id = 1;
[size=12px][b]创建数据库:
[/b]mysql> [color=orange][b]CREATE DATABASE[/b][/color] dbname;
为了处理数据库,命令解释器需要用户在能够发布SQL语句之前使用数据库。在[u][b][color=#810081]MySql[/color][/b][/u]解释器中可以发布以下命令:
mysql> [color=orange][b]use[/b][/color] dbname
以下省略命令例子的mysql>提示符。
[b]创建表格:[/b]
[color=orange][b]CREATE TABLE[/b][/color] 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),
[color=orange][b]PRIMARY KEY[/b][/color] (c_u_id),
[color=orange][b]KEY[/b][/color] names (c_u_name)
);
[b]CREATE TABLE[/b]语句有3个部分: [list][*]在[b]CREATE TABLE[/b]语句后面是一个自由形式的表名称------在本例是cooya_users。[*]开始圆括号后面是一个属性名、类型、和修饰字的列表。[*]属性列表后面是一列键,也就是定义哪些属性满足主键的唯一性约束,以及哪些属性将为了快速访问而加以索引。[/list][b]更改表和索引:[/b]
[b]添加索引:[/b]
[color=orange][b]ALTER TABLE[/b][/color] cooya_users [color=orange][b]ADD INDEX[/b][/color] cities (city);
[b]删除索引:[/b]
[color=orange][b]ALTER TABLE[/b][/color] cooya_users [color=orange][b]DROP INDEX[/b][/color] cities;[/size]
用show显示数据库结构
[size=12px][color=orange][b]SHOW DATABASES[/b][/color]
列出 My SQL DBMS 可访问的数据库。
[b][color=orange]SHOW TABLES[/color][/b]
显示已用 use 命令选定的数据库中的表。
[b][color=orange]SHOW COLUMNS FROM tablename[/color][/b]
显示属性、属性的类型、鍵信息、是否允许NULL、默认值,以及表的其他信息。
例如:
[b][color=orange]SHOW COLUMNS FROM customer[/color][/b]
显示 customer 表的属性信息。DESCRIBE table 产生相同的输出。
[b][color=orange]SHOW INDEX FROM tablename
[/color][/b] 展示表中所有索引的详细信息,包括 PRIMARY KEY。
例如:
[b][color=orange]SHOW INDEX FROM customer[/color][/b]
显示有两个索引,即主索引和 names 索引。
[b][color=orange]SHOW STATUS[/color][/b]
[u][b][color=#810081]报告[/color][/b][/u] MYSQL DBMS 性能和统计的详细信息。
[size=12px]MySQL的转义字符“\”
MySQL识别下列转义字符:
\0
一个ASCII 0 (NUL)字符。
\n
一个新行符。
\t
一个定位符。
\r
一个回车符。
\b
一个退格符。
\'
一个单引号(“'”)符。
\ "
一个双引号(“ "”)符。
\\
一个反斜线(“\”)符。
\%
一个“%”符。它用于在正文中搜索“%”的文字实例,否则这里“%”将解释为一个通配符。
\_ 一个“_”符。它用于在正文中搜索“_”的文字实例,否则这里“_”将解释为一个通配符。
注意,如果你在某些正文环境中使用“\%”或“\%_”,这些将返回字符串“\%”和“\_”而不是“%”和“_”。
★★
有几种方法在一个字符串内包括引号:
1、必须转义的:
一个字符串用单引号“'”来引用的,该字符串中的单引号“'”字符可以用“''”方式转义。
一个字符串用双引号“ "”来引用的,该字符串中的“ "”字符可以用“ " "”方式转义。
同时你也可以继续使用一个转义字符“\”来转义
2、可不转义的:
一个字符串用双引号“ "”来引用的,该字符串中的单引号“'”不需要特殊对待而且不必被重复或转义。同理,一个字符串用单引号“'”来引用的,该字符串中的双引号“ "”不需要特殊对待而且不必被重复或转义。
下面显示的SELECT演示引号和转义如何[u][b][color=#810081]工作[/color][/b][/u]:
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,双引号。用“\ "”表示。[/size]
[/size]
页:
[1]