1. /**操作数据库*/
  2. SHOW DATABASES;
  3. CREATE DATABASE db;
  4. SHOW DATABASES;
  5. DROP DATABASE db;
  6. /**操作表*/
  7. USE  db;
  8. SHOW TABLES;
  9. CREATE TABLE IF NOT EXISTS student(
  10. stu_id  INT PRIMARY KEY NOT NULL AUTO_INCREMENT,
  11. stu_name VARCHAR(20) NOT NULL DEFAULT '',
  12. stu_age  INT   NOT NULL DEFAULT 0,
  13. stu_birthday    DATE,
  14. stu_salary FLOAT DEFAULT '0.1'
  15. #外键在这里修饰
  16. );
  17. DESCRIBE  student;
  18. /**对表中的列操作*/
  19. ALTER TABLE student ADD COLUMN stu_grade INT NOT NULL;
  20. ALTER TABLE student DROP COLUMN stu_grade;
  21. /**简单的增删改表操作*/
  22. INSERT INTO student VALUES(1,'张三',23,'1991-01-23','');
  23. INSERT INTO student (stu_name,stu_age,stu_birthday) VALUES('李四',22,'1992-1-2');
  24. INSERT INTO student (stu_name,stu_age) VALUES('王五',22);
  25. UPDATE student SET stu_name='张阳阳' WHERE stu_id=1;
  26. UPDATE student SET stu_name='张阳阳',stu_age=23 WHERE stu_id=1;
  27. DELETE FROM  student WHERE stu_id=1;
  28. /**将表student的数据导入到表teacher中
  29. 注意:所要导入的字段类型一定要一致
  30. */
  31. CREATE TABLE IF NOT EXISTS teacher(
  32. tea_id  INT PRIMARY KEY NOT NULL AUTO_INCREMENT,
  33. tea_name VARCHAR(20) NOT NULL DEFAULT '',
  34. tea_age  INT   NOT NULL DEFAULT 0,
  35. tea_birthday    DATE,
  36. tea_salary FLOAT DEFAULT '0.1'
  37. #外键在这里修饰
  38. );
  39. INSERT INTO teacher SELECT * FROM student;
  40. INSERT INTO teacher (tea_name,tea_age) SELECT stu_name,stu_age FROM student WHERE stu_age=22;
  41. /**简单查询操作*/
  42. #Mysql默认的查询方式是ASC(升序);   降序(DESC)
  43. /**查询格式:
  44. SELECT 属性列表
  45. FROM 表名和视图列表
  46. [WHERE 条件表达式1]
  47. [GROUP BY 属性名1] [HAVING 条件表达式2]
  48. [ORDER BY 属性名[ASC|DESC]]
  49. */
  50. /**
  51. 附: 理解SQL语句执行过程的核心原理:
  52. 下面是带有WHERE和HAVING的SELECT语句执行过程:
  53. 1、执行WHERE筛选数据
  54. 2、执行GROUP BY分组形成中间分组表
  55. 3、执行WITH ROLLUP/CUBE生成统计分析数据记录并加入中间分组表
  56. 4、执行HAVING筛选中间分组表
  57. 5、执行ORDER BY排序
  58. 知道了执行过程,神秘的GROUP/WHERE/HAVING/WITH...将不再神秘。
  59. */
  60. /**GROUP BY 和 HAVING的理解:
  61. GROUP BY 是将查询结果按照某一列或者多列的值分组,值相等的为一组。
  62. 对查询结果分组的目的是为了细化聚集函数的作用对象。如查询各个地区的人口,只能使用利用(GROUP BY 区域字段)来查询
  63. HAVING 是在基于GROUP BY分组之后的数据中再利用所要分组的字段进行条件筛选
  64. */
  65. SELECT * FROM student;
  66. SELECT * FROM student WHERE stu_age=22;
  67. SELECT stu_name,stu_age,stu_birthday FROM student WHERE stu_age=22;
  68. SELECT stu_name AS '学生姓名',stu_age AS '年龄' FROM student ORDER BY stu_age; #用AS将显示字段自定义
  69. SELECT * FROM student WHERE stu_name IN ('张三','王五'); #用IN限定范围查找
  70. SELECT * FROM student WHERE stu_age BETWEEN 0 AND 22; #用BETWEEN AND进行查找
  71. SELECT * FROM student WHERE stu_age>= 23;    # 用比较测试符:(包括=,<>,<,<=,>,>=) 查询
  72. /**(注意查询条件中有“%”,则说明是部分匹配,而且还有先后信息在里面,即查找以“李”开头的匹配项。
  73. 所以若查询有“李”的所有对象,应该命令:'% 李%';若是第二个字为李,则应为'_李%'或'_李'或'_李_'。)*/
  74. SELECT * FROM student WHERE stu_name like '%李%';
  75. SELECT * FROM student WHERE stu_name like '_李%';
  76. SELECT * FROM student WHERE stu_name IS NOT NULL  # IS[NOT] NULL
  77. SELECT COUNT(*) FROM student;
  78. SELECT avg(stu_age) FROM student;
  79. SELECT max(stu_age) FROM student;
  80. SELECT min(stu_age) FROM student;
  81. SELECT * FROM student LIMIT X,Y;  #X代表从哪个下标开始,Y代表从X开始,查询Y个数据
  82. /**连接查询**/
  83. /**连接查询定义:连接查询是将两个或两个以上的表按某个条件连接起来,
  84. 从中选取需要的数据。连接查询是同时查询两个或两个以上的表时使用的。
  85. 当不同的表中存在表示相同意义的字段时,可以通过该字段来连接这几个表。*/
  86. CREATE TABLE employee(
  87. num INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
  88. d_id INT NULL,  #外键(department)
  89. name VARCHAR(20),
  90. age INT ,
  91. gender VARCHAR(20),
  92. homeaddr VARCHAR(50)
  93. )
  94. INSERT INTO employee VALUES
  95. (NULL, 1001, '张三', 26, '男', '北京市海淀区'),
  96. (NULL, 1001, '李四', 24, '女', '北京市昌平区'),
  97. (NULL, 1002, '王五', 25, '男', '湖南长沙市'),
  98. (NULL, 1004, 'Aric', 15, '男', 'England');
  99. CREATE TABLE department(
  100. d_id INT PRIMARY KEY NOT NULL AUTO_INCREMENT,
  101. d_name VARCHAR(20) NOT NULL,
  102. function VARCHAR(50),
  103. address VARCHAR(50)
  104. )
  105. CREATE TABLE worker(
  106. id INT PRIMARY KEY AUTO_INCREMENT,
  107. num INT(10),    #员工编号
  108. d_id INT(50),   #部门号(外键)
  109. name VARCHAR(20), #姓名
  110. gender VARCHAR(10), #性别
  111. birthday DATE, #出生日期
  112. address VARCHAR(50),  #家庭住址
  113. FOREIGN KEY(d_id) REFERENCES department(d_id)
  114. )
  115. INSERT INTO department VALUES(1004, '人力资源部', '管理员工的信息', '2号楼3层');
  116. INSERT INTO employee VALUES(NULL, 1003, '刘花', 28, '女', '吉林省长春市');
  117. INSERT INTO employee VALUES(NULL, 1006, '王晶', 22, '女', '吉林省通化市');
  118. /**内连接查询*/
  119. /**内连接查询:内连接查询可以查询两个或两个以上的表。当两个表中存在表示相同意义的字段时,
  120. 可以通过该字段来连接这两个表。当该字段的值相等时,就查询出该记录*/
  121. SELECT num AS '雇员ID',name,age,gender,homeaddr,d_name,function,address FROM employee,department
  122. WHERE employee.d_id=department.d_id;
  123. /**外连接查询*/
  124. /**外连接查询:外连接查询可以查询两个或两个以上的表。外连接查询也需要通过指定字段来进行连接。
  125. 当该字段取值相等时,可以查询该记录。而且,该字段取值不相等的记录也可以查询出来。
  126. 外连接查询包括左连接查询和右连接查询。*/
  127. /**外连接查询基本语法:
  128. SELECT 属性名列表
  129. FROM 表名1(左) LEFT|RIGHT JOIN 表名2(右)
  130. ON 表名1.属性名1 = 表名2.属性名2;
  131. */
  132. SELECT num, name, employee.d_id,age,gender, d_name, function
  133. FROM employee LEFT JOIN department
  134. ON employee.d_id=department.d_id;
  135. SELECT num, name, employee.d_id,age,gender, d_name, function
  136. FROM employee RIGHT JOIN department
  137. ON employee.d_id=department.d_id;
  138. CREATE TABLE performance(
  139. id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
  140. e_num INT(10) NOT NULL UNIQUE,
  141. performance FLOAT NOT NULL DEFAULT 0
  142. ) DEFAULT CHARSET=utf8;
  143. INSERT INTO performance VALUES
  144. (NULL, 2, 2000),
  145. (NULL, 1, 100),
  146. (NULL, 3, 5000),
  147. (NULL, 5, 8000),
  148. (NULL, 6, 10000);
  149. /**多个左右连接查询*/
  150. SELECT num, name, employee.d_id,age,gender, d_name, function, performance
  151. FROM employee
  152. LEFT JOIN department
  153. ON employee.d_id=department.d_id
  154. LEFT JOIN performance
  155. ON employee.num=performance.id;
  156. /**复合条件连接查询*/
  157. SELECT num,name,employee.d_id,age,gender,d_name,function
  158. FROM employee,department
  159. WHERE employee.d_id=department.d_id
  160. AND age>=1
  161. ORDER BY age DESC;
  162. /**子查询*/
  163. /**定义:子查询是将一个查询语句嵌套在另一个查询语句中。
  164. 内层查询语句的查询结果,可以为外层查询语句提供查询条件。
  165. 子查询中可能包括IN、NOT IN、ANY、ALL、EXISTS、NOT EXISTS等关键字。
  166. 子查询中还可能包含比较运算符,如'='、'!='、'>'和'<'等。        */
  167. SELECT * FROM employee
  168. WHERE d_id IN(SELECT d_id FROM department); /**IN关键字子查询*/
  169. CREATE TABLE computer_stu(
  170. id INT PRIMARY KEY,
  171. name VARCHAR(20),
  172. score FLOAT
  173. ) DEFAULT CHARSET=utf8;
  174. INSERT INTO computer_stu VALUES(1001, 'lILY', 85);
  175. INSERT INTO computer_stu VALUES(1002, 'Tom', 91);
  176. INSERT INTO computer_stu VALUES(1003, 'Jim', 87);
  177. INSERT INTO computer_stu VALUES(1004, 'Aric', 77);
  178. INSERT INTO computer_stu VALUES(1005, 'Lucy', 65);
  179. INSERT INTO computer_stu VALUES(1006, 'Andy', 99);
  180. INSERT INTO computer_stu VALUES(1007, 'Ada', 85);
  181. INSERT INTO computer_stu VALUES(1008, 'jeck', 70);
  182. CREATE TABLE scholarship(
  183. level INT PRIMARY KEY,
  184. score INT
  185. ) DEFAULT CHARSET=utf8;
  186. INSERT INTO scholarship VALUES(1, 90);
  187. INSERT INTO scholarship VALUES(2, 80);
  188. INSERT INTO scholarship VALUES(3, 70);
  189. /**在computer_stu表中查询获得一等奖学金的学生的学号、姓名和分数*/
  190. SELECT com.id,com.name,com.score FROM computer_stu as com
  191. WHERE score>=(SELECT score FROM scholarship WHERE level=1);
  192. /**在department表中查询哪些部门没有年龄为24岁的员工*/
  193. SELECT  dep.d_name FROM department as dep
  194. WHERE dep.d_id IN(SELECT emp.d_id FROM employee as emp WHERE emp.age!=24);
  195. /**EXISTS关键字的子查询*/
  196. /**定义:EXISTS关键字表示存在。使用EXISTS关键字时,内层查询语句不返回查询的记录。
  197. 而是返回一个真假值。如果内层查询语句查询到满足条件的记录,就返回一个真值(TRUE)。
  198. 否则,将返回一个假值(FALSE)。当返回的值是真值时,外层查询语句将进行查询。当返回值是假值时,
  199. 外层查询语句不再进行查询或者查询不出任何记录*/
  200. /**如果department表中存在d_id取值为1003的记录,则查询employee表的记录*/
  201. SELECT * FROM employee
  202. WHERE EXISTS(SELECT * FROM department WHERE d_id=1003);
  203. /**如果department表中存在d_id取值为1003的记录,则查询employee表中age大于24的记录*/
  204. SELECT * FROM employee as emp
  205. WHERE emp.age>0 AND EXISTS (SELECT * FROM department WHERE d_id=1003);
  206. /**ANY关键字的子查询*/
  207. /**定义:ANY关键字表示满足其中任一条件。使用ANY关键字时,只要满足内层查询语句返回的结果中的任何一个,
  208. 就可以通过该条件来执行外层查询语句*/
  209. /**从computer_stu表中查询哪些同学可以获得奖学金。奖学金的信息存储在scholarship表中*/
  210. SELECT * FROM computer_stu as coms
  211. WHERE coms.score>= ANY(SELECT score FROM scholarship) ORDER BY score DESC;
  212. /**ALL关键字的子查询*/
  213. /**定义:ALL关键字表示满足所有条件。使用ALL关键字时,只有满足内层查询语句返回的所有结果,
  214. 才可以执行外层查询语句*/
  215. /**查询哪些同学能够获得一等奖学金*/
  216. SELECT * FROM computer_stu as coms
  217. WHERE coms.score>=ALL(SELECT score FROM scholarship)
  218. /**UNION关键字合并查询结果*/
  219. /**合并查询结构是将多个SELECT语句的查询结果合并到一起。
  220. 因为某种情况下,需要将几个SELECT语句查询出来的结果合并起来显示*/
  221. /**使用条件:注: 使用 UNION 时 前一个 select column的个数要等于后一个select column的个数*/
  222. UNION和UNION ALL关键字都是将两个结果集合并为一个
  223. UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果;
  224. UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了
  225. /***distinct关键字*/
  226. 该关键字是去掉某个属性的重复操作,或者是去重操作后的计数,而且返回值只能是这一个属性的结果集,如果返回结果集里面含有多个字段,将是对多个属性同时起作用(也就达不到这个关键字的初衷),
  227. 详细的看 http://jxtm.jzu.cn/?p=258
  228. /***REPLACE 语句替换数据*/
  229. /***定义:如果使用INSERT语句插入数据时,在表中已经有相同数据时(指的是PRIMARYT KEY或UNIQUE字段相同数据)会发生错误。
  230. 而REPLACE INTO语句会删除原有相同数据而插入新的数据*/
  231. /***ps:此种方法目的何在???这种需求可以用UPDATE更新*/
  232. INSERT INTO product VALUES
  233. (1005, '头疼灵1号', '治疗头疼', 'DD制药厂', '北京市房山区');
  234. REPLACE INTO product VALUES
  235. (1005, '头疼灵1号_replace', '治疗头疼', 'DD制药厂', '北京市房山区');
  236. /***问题1:如何为自增字段(AUTO_INCREMENT)赋值??*/
  237. /***方案:第一种方法是在INSERT语句中不为该字段赋值。第二种方法是在INSERT语句中将该字段赋值为NULL/
  238. /**连接Mysql(小写)*/
  239. mysql -h(IP) -u(用户名) -p(密码)
  240. /**修改mysql密码
  241. 前提:进入目录mysqlbin
  242. */
  243. mysqladmin -u用户名 -p旧密码 password 新密码
  244. /**授权新用户管理数据库*/
  245. /*1.授权用户在任意PC管理该数据库中的任意数据信息*/
  246. grant  update,select,insert,delete on *.* to zyy1@"%" identified by "zyy1";
  247. grant  all on *.* to zyy2@"%" identified by "zyy2";
  248. grant  update,select,insert on *.* to zyy3@"%" identified by "zyy3";
  249. /*2.授权用户只能在特定的PC管理该数据库中指定的db子数据库数据信息*/
  250. grant  update,select,insert,delete on db.* to zyy4@localhost identified by "zyy4";
  251. /**数据库的备份
  252. 前提:进入到bin目录下
  253. */
  254. mysqldump -hlocalhost -uroot -p123456 db>C:\\db.sql
  255. mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql
  256. /*备份MySQL数据库的命令*/
  257. mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql
  258. /*备份MySQL数据库为带删除表的格式
  259. 备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
  260. */
  261. mysqldump -–add-drop-table -uusername -ppassword databasename > backupfile.sql
  262. /*直接将MySQL数据库压缩备份*/
  263. mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz
  264. /*备份MySQL数据库某个(些)表*/
  265. mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql
  266. /*同时备份多个MySQL数据库*/
  267. mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql
  268. /*仅仅备份数据库结构*/
  269. mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql
  270. /*备份服务器上所有数据库*/
  271. mysqldump –all-databases > allbackupfile.sql
  272. /*还原MySQL数据库的命令*/
  273. mysql -hhostname -uusername -ppassword databasename < backupfile.sql
  274. /*还原压缩的MySQL数据库*/
  275. gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
  276. /*将数据库转移到新服务器*/
  277. mysqldump -uusername -ppassword databasename | mysql –host=*.*.*.* -C databasename
  278. /***索引:索引是与表或视图关联的磁盘上结构,可以加快从表或视图中检索行的速度。
  279. 索引由数据库表中一列或多列组合而成*/
  280. 索引介绍:http://www.jb51.net/article/49346.htm
  281. /**查看某个数据库表的索引*/
  282. SHOW INDEX FROM app_account(表名称)
  283. /***
  284. CREATE TABLE index_tbl_1 (
  285. id INT,
  286. name VARCHAR(20),
  287. gender BOOLEAN,
  288. INDEX(id)
  289. );
  290. */
  291. /**视图*/
  292. /**
  293. *视图是一种虚拟的表。视图从数据库中的一个或多个表导出来的表。视图还可以从已经存在的视图的基础上定义
  294. 。数据库只存放了视图的定义,而并没有存放视图中的数据。这些数据存放在原来的表中。使用视图查询数据时,
  295. 数据库系统会从原来的表中取出对应的数据。因此,视图中的数据是依赖于原来的表中的数据的。一旦表中的数据
  296. 发生改变,显示在视图中的数据也会发生改变。
  297. */
  298. /**视图作用:
  299. 1. 使操作简单化
  300. 2. 增加数据的安全性
  301. 3. 提高表的逻辑独立性
  302. */
  303. /**
  304. MySQL中,创建视图是通过SQL语句CREATE VIEW实现的。其语法形式如下 :
  305. CREATE [ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}]
  306. VIEW 视图名 [(属性清单)]
  307. AS SELECT语句
  308. [WITH[CASCADED|LOCAL] CHECK OPTION];
  309. ALGORITHM:
  310. UNDEFINED, MySQL将自动选择所要使用的算法;
  311. MERGE, 表示将使用视图的语句与视图定义合并起来,使用视图定义的某一部分取代语句的对应部分;
  312. TEMPTABLE, 表示将视图的结果存入临时表,然后使用临时表执行语句。
  313. CASCADED是可选参数,表示更新视图时要满足所有视图和表的条件,该参数默认值;"LOCAL"表示更新视图时要满足
  314. 该视图本身的定义的条件即可。
  315. */
  316. /**
  317. 在单表上创建视图
  318. MySQL中可以在单个表上创建视图。在department表上创建一个简单的视图,视图的名称为department_view。
  319. 实例一:
  320. USE db;
  321. CREATE VIEW department_view1
  322. AS SELECT * FROM db.department;
  323. DESC department_view;
  324. 实例二:
  325. CREATE VIEW department_view2(name, function,location)
  326. AS SELECT d_name, function, address FROM db.department;
  327. DESC department_view2;
  328. */
  329. /**
  330. MySQL中也可以在两个或两个以上的表上创建视图,也是使用CREATE VIEW语句实现的。
  331. 下面在department表和worker表上创建一个名为worker_view1的视图。
  332. 实例一:
  333. CREATE ALGORITHM=MERGE VIEW
  334. worker_view1(name, department, gender, age, address)
  335. AS SELECT name, department.d_name, gender, 2011-birthday, worker.address
  336. FROM worker,department WHERE worker.d_id=department.d_id
  337. WITH LOCAL CHECK OPTION;
  338. */
  339. /**
  340. 查看视图
  341. 查看视图是指查看数据库中已存在的视图的定义。查看视图必须要有SHOW VIEW的权限,mysql数据库下的user表
  342. 中保存着这个信息。查看视图的方法包括DESCRIBE语句、SHOW TABLE STATUS语句、SHOW CREATE VIEW语句和查询
  343. information_schema数据库下的views表等
  344. */
  345. /**注意:并不是所有的视图都可以更新的。以下这几中情况是不能更新视图的
  346. 1.视图中包含sum()、count()、max()、min()等函数
  347. 2.视图中包含union、 union all、distinct、group by、having等关键字。
  348. 3.常量视图
  349. 4.视图中的SELECT中包含子查询
  350. 5.由不可更新的视图导出的视图。
  351. 6.创建视图时,ALGORITHM为TEMPTABLE类型。
  352. 7.视图对应的表上存在没有默认值的列,而且该列没有包含在视图里
  353. 附加:一般视图只在查询的时候使用,如果在更新数据的时候使用视图,则有可能出现如果没有全面考虑在视图中更新数据的限制,
  354. 可能会造成数据更新失败。
  355. */
  356. /*操作外键*/
  357. 查看外键:
  358. SHOW CREATE TABLE subscriber(表名称)
  359. 显示如:
  360. CREATE TABLE `subscriber` (
  361. `subscriber_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '订阅者身份标识',
  362. `app_account_id` int(11) NOT NULL COMMENT 'app_account表主键',
  363. `subscribe_status` char(1) NOT NULL COMMENT '订阅状态 0 关闭 1开启',
  364. `push_url` varchar(256) DEFAULT NULL COMMENT '业务推送地址',
  365. `business_flag` char(1) DEFAULT NULL COMMENT '业务标识',
  366. `note` varchar(256) DEFAULT NULL COMMENT '备注',
  367. `subscriber_name` varchar(64) NOT NULL COMMENT '订阅者名称',
  368. PRIMARY KEY (`subscriber_id`),
  369. KEY `subscription_info_app_account` (`app_account_id`),
  370. CONSTRAINT `subscriber_ibfk_1` FOREIGN KEY (`app_account_id`) REFERENCES `app_account` (`app_account_id`)
  371. ) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='订阅者表'
  372. //注意:在我进行操作外键时,如果不删除之前的数据,就会出现错误,删除掉数据之后,删除或者添加外键没有问题
  373. 删掉该外键:
  374. ALTER TABLE subscriber DROP FOREIGN KEY subscriber_ibfk_1;  #记录
  375. 添加外键:
  376. ALTER TABLE subscriber ADD CONSTRAINT FK_ID FOREIGN KEY(app_account_id) REFERENCES app_account(app_account_id)
  377. show TRIGGERS
  378. /**触发器*/
  379. /**
  380. 触发器(TRIGGER)是由事件来触发某个操作。这些事件包括INSERT语句、UPDATE语句和DELETE语句。
  381. 当数据库系统执行这些事件时,就会激活触发器执行相应的操作.
  382. 触发器触发的执行语句可能只有一个,也可能有多个.
  383. */
  384. /**项目中的技巧:如:新闻表中每查看一下新闻,则浏览数将+1,这种情况下使用触发器,是非常方便的*/
  385. /**
  386. MySQL中,创建只有一个执行语句的触发器的基本形式如下 :
  387. CREATE TRIGGER 触发器名 BEFORE | AFTER 触发事件
  388. ON 表名 FOR EACH ROW 执行语句
  389. “触发器名”参数指要创建的触发器的名字。
  390. “BEFORE”和“AFTER”参数指定了触发器执行的时间。“BEFORE”指在触发事件之前执行触发语句。“AFTER”表示在触发事件之后执行触发语句。
  391. “触发事件”参数批触发的条件,其中包括INERT、UPDATE和DELETE。
  392. “表名”参数指触发事件操作的表的名称。
  393. “FOR EACH ROW”表示任何一条记录上的操作满足触发事件都会触发都会触发该触发器。
  394. “执行语句”参数指触发器被触发执行的程序。
  395. */
  396. /**存储过程*/

Mysql常用命令行大全(三)的更多相关文章

  1. php开发面试题---Mysql常用命令行大全

    php开发面试题---Mysql常用命令行大全 一.总结 一句话总结: 常见关键词:create,use,drop,insert,update,select,where ,from.inner joi ...

  2. Mysql常用命令行大全

    第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ...

  3. Mysql常用命令行大全——转载

    转载地址:http://www.blogjava.net/supperchen/archive/2012/10/11/389340.html 第一招.mysql服务的启动和停止 net stop my ...

  4. Mysql常用命令行大全(转)

    第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ...

  5. Mysql常用命令行大全(一)

    登录到mysql中,然后在mysql的提示符下运行下列命令,每个命令以分号结束. 1. 显示数据库列表. show databases; 缺省有两个数据库:mysql和test. mysql库存放着m ...

  6. Mysql常用命令行大全(转)

    第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ...

  7. Mysql常用命令行大全(二)

    #登录数据库mysql -hlocalhost -uroot -p;#修改密码mysqladmin -uroot -pold password new; #显示数据库show databases;#显 ...

  8. Mysql常用命令行大全(四)外键及其它

    表构成 mysql> show tables; +----------------------+| Tables_in_WebComplie |+----------------------+| ...

  9. (转)Mysql常用命令行

    原文:http://www.cnblogs.com/TsengYuen/archive/2012/01/11/2319034.html Mysql常用命令行 Mysql经常使用号令行大全 熬头招.my ...

随机推荐

  1. 【Unity3D】【NGUI】Atlas的动态创建

    NGUI版本号:3.6.5 1.參见SZUIAtlasMakerRuntimeTest设置对应的值以上值须要提前设置好 2.没有检查是否atlas可以正确创建,自己可以改,增加返回值 3.代码都是在N ...

  2. 移除WordPress文章图片的宽度和高度属性

    通过WordPress自身的媒体上传功能插入到文章的图片,都会默认添加了高度和宽度属性: <img title="使用 Chrome Workspace 进行网站调试 | 倡萌的自留地 ...

  3. 20-ab压力测试及nginx性能统计模块

    一:找到apache ab模块. ab -c 1000 -n 50000 http://127.0.0.1/index.html 查看信息: 超过1024个线程 出现错误,说打开文件太多了.cket: ...

  4. Windows/Linux 环境搭建Git服务器 + vs2012集成git

    1. 下载.安装Git 我的系统是Windows 7,需要安装Git for Windows. 下载地址: http://code.google.com/p/msysgit/downloads/lis ...

  5. 在ios开发中使用 try 和 catch 来捕获错误。

    本文转载至 http://blog.csdn.net/remote_roamer/article/details/7105776 抛出错误的代码 //如果返回的报文是错误信息,则抛出错误 if([ou ...

  6. 实现RTSP网站微信直播方案EasyNVR(linux版)部署问题之:ERR_CONTENT_LENGTH_MISMATCH

    发现问题: 想要优化一下EasyNVR相关功能,内部测试软件,于是在linux系统中部署了一台EasyNVR.当部署好,运行起来发现问题: EasyNVR的配置页面数据出不来. 分析问题: 基于是we ...

  7. 性能测试--初识Jmeter

    初识Jmeter Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域. 它可以用于测试静态和动 ...

  8. java多线程---基础

    一, java多线程----线程与进程 进程: 程序(任务)的执行过程,拥有资源(共享内存,共享资源)和线程(一个或者多个,至少一个).  例如:打开任务管理器,qq,chrome,都属于进程. 线程 ...

  9. Java互斥语义的实现

    锁 对象头(Object Header) HotSpot 虚拟机的对象头包括两部分信息:Mark Word(标记字段)和 Klass Pointer(类型指针)   Mark Word 用于存储对象自 ...

  10. 获取原生的DOM方式,DIY脚手架,vue-cli的使用

    一 . 获取原生的DOM的方式 在js中,我们可以通过id, class 或者标签获取DOM元素,vue中也为我们提供了获取原生DOM的方法,就是给标签或者组件添加 ref 属性,通过 this.$r ...