1.Insert语句:

INSERT [INTO] table [(column1, column2, column3, . . .)] VALUES(value1, value2, value3, . . .);

例:INSERT INTO user VALUES(NULL, 'test', '123456');

例:INSERT INTO user (username, password) VALUES('test', '123456');

实际上另一种方式:

例:INSERT INTO user SET username='test', password='123456';

2.查询语句:
SELECT [option] item [INTO file_details] FROM tables [WHERE condition] [GROUP BY group_type] [HAVING where_definition]
[ORDER BY order_type] [LIMIT limit_criteria] [PROCEDURE proc_name(arguments)] [lock_option];
①简单查询
例:SELECT * FROM user WHERE uid=4;
②多表查询
主要的多表查询
例:SELECT user.username, userinfo.age, userinfo.sex, userinfo.phone FROM user, userinfo WHERE user.uid=userinfo.uid;
左关联
SELECT user.uid, uid.name, orders.orderid FROM user LEFT JOIN orders ON user.uid=orders.uid;
在没有使用做关联的情况下仅仅会返回满足条件的记录,假设使用左关联左表将所有返回即使右表并不匹配,所查的右边的值将用NULL取代
(换句话说:左关联将返回全部满足条件的记录。还会将左表没有返回的记录也返回,所需的右表数据如orders.orderid用NULL填充)
③使用子查询
主要的子查询
例:SELECT uid, amount FROM orders WHERE amount=(SELECT max(amount) FROM orders);
关联子查询
例:SELECT isbn, title FROM books WHERE exists (SELECT * FROM orders WHERE orders.isbn=books.isbn);
//内部查询引用外部查询数据
行子查询
例:SELECT c1, c2, c3 FROM t1 WHERE (c1, c2, c3) IN (SELECT c1, c2, c3 FROM t2);
使用子查询作为暂时表
例:SELECT * FROM (SELECT uid, username FROM user WHERE city='Beijing') AS user_beijing;
④合计函数与分组
合计函数:
avg()
count()
min()
max()
std()
stddev()
sum()
. . . 
分组通常结合合计函数使用。对结果集进行分组
例:SELECT uid, avg(amount) FROM orders GROUP BY uid;
HAVING类似于WHERE,仅仅用于合计与分组,SQL中添加HAVING的原因是。WHERE中无法使用合计函数
例:SELECT uid, avg(amount) FROM orders GROUP BY uid HAVING avg(amount)>100;
⑤排序与限制的使用
例:SELECT username, password FROM user ORDER BY username ASC;    //查询user表并按username字段升序排序
例:SELECT username, password FROM user ORDER BY uid DESC;    //查询user表并按uid字段降序排序
例:SELECT username, password FROM user LIMIT 4;    //查询user表前四条记录
例:SELECT username, password FROM user LIMIT 3, 4;    //查询user表从第三条開始之后4条记录

3.更新语句:
UPDATE [LOW_PRIORITY] [IGNORE] table SET column=expression1, column2=expression2, . . .
[WHERE condition] [ORDER BY order_criteria] [LIMIT number];
例:UPDATE user SET password='111111';    //将user表中全部人密码设成111111
例:UPDATE user SET password='111111' WHERE uid=4;    //将user表中uid等于4的记录的密码设成111111
例:UPDATE user SET password='111111'    ORDER BY uid DESC LIMIT 5;    //将user表中按uid倒序的前5条记录的密码设成111111
这里的ORDER BY通常与LIMIT结合使用,单独使用ORDER BY没有意义

4.删除语言:
DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM table [WHERE condition] [ORDER BY order_cols] [LIMIT number];
例:DELETE FROM user;    //删除user全部数据
例:DELETE FROM user WHERE uid=4;    //删除uid=4的记录
例:DELETE FROM user ORDER BY uid DESC LIMIT 5;    //删除user表中按uid倒序的前5条数据

提示:[]表示可选
           在字段名上加上反引號``能够避免字段名与数据库keyword冲突
           弦值需要使用引号''行情,号码值不需要

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

SQL于DML(数据库操作语言)采用的更多相关文章

  1. DML数据操作语言

    DML数据操作语言 用来对数据库中表的数据记录进行更新.(增删改) 插入insert -- insert into 表(列名1,列名2,列名3...) values (值1,值2,值3...):向表中 ...

  2. 6.1课堂笔记—DML(数据操作语言),DQL查询语句

    一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...

  3. SQL语句之数据库操作

    SQL语句系列 1.SQL语句之行操作 2.SQL语句之表操作 3.SQL语句之数据库操作 4.SQL语句之用户管理 占坑,带写……

  4. DML数据操作语言之增加,删除,更新

    1.数据的增加 数据的增加要用到insert语句  ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...

  5. 利用SQL Profiler 追踪数据库操作

    SQL Server 事件探查器 是一个界面,用于创建和管理跟踪并分析和重播跟踪结果. 这些事件保存在一个跟踪文件中,稍后试图诊断问题时,可以对该文件进行分析或用它来重播一系列特定的步骤. SQL S ...

  6. SQL Server远程数据库操作(备份、还原等)

    · SQL Server远程数据库备份到本地: exp sauser/sapassword@192.168.8.233:1433/DBName file=d:/backup.dmp OWNER=sum ...

  7. SQL语句总结---数据库操作

    https://blog.csdn.net/hallomrzhang/article/details/85010014 数据库操作 查看所有数据库 show databases; 1 查看当前使用的数 ...

  8. DML(数据库操作语言)(六)

    一.INSERT插入语句 语法: INTERT INTO 表名(列名1,列名2, ...) VALUES(列值1, 列值2, ...);# 在表名后给出要插入的列名,其他没有指定的列等同与插入null ...

  9. MySQL SQL DML (数据操作语言)

    包括 SELECT, UPDATE, DELETE, INSERT SELECT 从数据库表中获取数据 用法 SELECT name FROM students; SELECT name,age FR ...

随机推荐

  1. c++ primer 函数传值1

    不看c++ primer  永远不知道自己基础有多差 函数的參数传值一般有两种方式:值传递,引用传递. 值传递有以下两种形式: void func( int a ) { // } void func1 ...

  2. Apidemos--&gt;Views-Lists-Cursor(people)学�

    Apidemos-->Views-Lists-Cursor(people)-主要用到了获取手机联系人信息,属于内容提供者的范畴,要想了解这方面的内容,能够參考官方docs /sdk/docs/g ...

  3. Leetcode 实施细节 Rotate Image

    本文senlie原版的,转载请保留此地址:http://blog.csdn.net/zhengsenlie Rotate Image Total Accepted: 15609 Total Submi ...

  4. 玩转Web之servlet(二)---servlet常见错误

    1>403:tomcat发生错误 2> 404 :意思是服务器依据请求资源路径,找不到对应的资源        解决:1.依据http://localhost:8080/Web工程名/ur ...

  5. android应用框架构建------AppManager

    体验一些Android应用程序开发的个人总结 当我们开发应用程序.经常有非常多非常多activity,在这一刻,我们需要一个activity堆栈,以帮助管理activity的finish和start. ...

  6. Windows无法启动OracleOraDb10g_home1TNSListener维修,1错误067

    Oracle服务无法启动,据报:Windows无法启动OracleOraDb10g_home1TNSListener维修,错误 1067:这个过程意外终止. 在网上找了好久也没弄好.说什么环境变量的又 ...

  7. cocos2d-x v3.2环境配置(现在3.x版本号可以配置该)

     这里介绍的是Windows环境下的cocos2d-x配置. 前提: •Windows 7+ •cocos2d-x v3.2版本号(能够在http://www.cocos2d-x.org/down ...

  8. (初稿)SQL Server 复制(Replication)系列(2)——事务复制搭建

    原文:(初稿)SQL Server 复制(Replication)系列(2)--事务复制搭建 本文演示如何搭建最基本的事务复制. 环境准备: 虚拟机2台: 服务器名分别为RepA和RepB,RepA为 ...

  9. C++中的class (2)

    class Father { protected void methodA(){ //do something } private void methodB(){//do something } } ...

  10. POJ 3280 Cheapest Palindrome (DP)

     Description Keeping track of all the cows can be a tricky task so Farmer John has installed a sys ...