2018-03-11 sql基础

创建数据库mysqladmin -u root -p create database_name

删除数据库mysqladmin -u root -p drop database_name

选择数据库use database_name

创建数据表CREATE TABLE table_name(column_name column_type);
create table test_tbl (
id int unsigned auto_increment,
title varchar(100) not null,
author varchar(40) not null,
sub_date date,
primary key(id)
)engine=InnoDB default charset=utf8;

查看表结构DESC table_name;

删除数据表DROP TABLE table_name;

插入数据INSERT INTO table_name (field1,field2,..) VALUES (value1,value2);

查询数据select column_name1,column_name2 from table_name
[WHERE Clause] [LIMIT N] [OFFSET M]
where
SELECT field1, field2,...fieldN FROM table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
字符串是不区分大小写的,可用BINARY关键字设定区分大小写

update
UPDATE table_name SET field1=new-value1, field2=new-value2
[WHERE Clause]

delete
DELETE FROM table_name
[WHERE Clause] 不指定where条件,则删除整表

like
SELECT field1, field2,...fieldN
FROM table_name
WHERE field1 LIKE condition1 [AND [OR]] filed2 = '%somevalue'

union
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [ALL | DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];
DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。ALL: 可选,返回所有结果集,包含重复数据。

order by
SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]

group by
SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;
函数:COUNT, SUM, AVG,
eg.SELECT name, COUNT(*) FROM employee_tbl GROUP BY name;
mysql> SELECT name, SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
+--------+--------------+
| name | singin_count |
+--------+--------------+
| 小丽 | 2 |
| 小明 | 7 |
| 小王 | 7 |
| NULL | 16 |
+--------+--------------+
其中记录 NULL 表示所有人的登录次数。
我们可以使用 coalesce 来设置一个可以取代 NUll 的名称,coalesce 语法:
select coalesce(a,b,c);
参数说明:如果a==null,则选择b;如果b==null,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没意义)。
以下实例中如果名字为空我们使用总数代替:
mysql> SELECT coalesce(name, '总数'), SUM(singin) as singin_count FROM employee_tbl GROUP BY name WITH ROLLUP;
+--------------------------+--------------+
| coalesce(name, '总数') | singin_count |
+--------------------------+--------------+
| 小丽 | 2 |
| 小明 | 7 |
| 小王 | 7 |
| 总数 | 16 |
+--------------------------+--------------+

join连接?
inner join获取两个表中字段匹配关系的记录。
left join获取左表所有记录,即使右表没有对应匹配的记录。
right join用于获取右表所有记录,即使左表没有对应匹配的记录。
select a.,b. from a inner join b on a.id = b.parent_id 取交集
select a.,b. from a left join b on a.id = b.parent_id 以a中所有查b
select a.,b. from a right join b on a.id = b.parent_id 以b中所有查a
select a.,b. from a full join b on a.id = b.parent_id 取并集

NULL
IS NULL: 当列的值是 NULL,此运算符返回 true。
IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
<=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true。
在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 false,即 NULL = NULL 返回false 。

正则
SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';

事务处理主要有两种方法:
1、用 BEGIN, ROLLBACK, COMMIT来实现
BEGIN 开始一个事务
ROLLBACK 事务回滚
COMMIT 事务确认
2、直接用 SET 来改变 MySQL 的自动提交模式:
SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交

mysql> begin; # 开始事务
mysql> insert into runoob_transaction_test value(5);
mysql> insert into runoob_transaction_test value(6);
mysql> commit; # 提交事务
mysql> select * from runoob_transaction_test;
+------+
| id |
+------+
| 5 |
| 6 |
+------+

mysql> begin; # 开始事务
mysql> insert into runoob_transaction_test values(7);
mysql> rollback; # 回滚
mysql> select * from runoob_transaction_test; # 因为回滚所以数据没有插入
+------+
| id |
+------+
| 5 |
| 6 |
+------+
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn, "set names utf8");
mysqli_select_db( $conn, 'RUNOOB' );
mysqli_query($conn, "SET AUTOCOMMIT=0"); // 设置为不自动提交,因为MYSQL默认立即执行
mysqli_begin_transaction($conn); // 开始事务定义

if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(8)"))
{
mysqli_query($conn, "ROLLBACK"); // 判断当执行失败时回滚
}

if(!mysqli_query($conn, "insert into runoob_transaction_test (id) values(9)"))
{
mysqli_query($conn, "ROLLBACK"); // 判断执行失败时回滚
}
mysqli_commit($conn); //执行事务
mysqli_close($conn);

alter
修改表或字段,如果数据表中只剩余一个字段则无法使用DROP来删除字段
ALTER TABLE testalter_tbl RENAME TO alter_tbl;//修改表名
ALTER TABLE testalter_tbl DROP id;//删除字段id
ALTER TABLE testalter_tbl ADD i INT [FIRST | AFTER column_c];//添加字段i在首位或某字段之后,默认添加至尾部
ALTER TABLE testalter_tbl MODIFY c CHAR(10);
ALTER TABLE testalter_tbl CHANGE i j BIGINT;
ALTER TABLE testalter_tbl MODIFY j BIGINT NOT NULL DEFAULT 100;//指定字段 j 为 NOT NULL 且默认值为100 。

索引
临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。
CREATE TEMPORARY TABLE SalesSummary (。。。)

复制表
使用SHOW CREATE TABLE 命令获取创建数据表(CREATE TABLE) 语句,该语句包含了原数据表的结构,索引等。再修改新表名称,创建复制表。
或者,
CREATE TABLE targetTable LIKE sourceTable;
INSERT INTO targetTable SELECT * FROM sourceTable;

第一、只复制表结构到新表
create table 新表 select * from 旧表 where 1=2
或者
create table 新表 like 旧表
第二、复制表结构及数据到新表
create table新表 select * from 旧表

sql注入?

你可能感兴趣的:(2018-03-11 sql基础)