一、Oracle LOCK TABLE语句(锁表)
LOCK TABLE ZIM_O02
IN SHARE /允许并发查询,但用户无法更新锁定的表
ROW SHARE /允许同时访问表,但阻止用户锁定整个表以进行独占访问。
ROW EXCLUSIVE /允许对表进行并发访问,但阻止用户以独占访问方式锁定整个表并以共享方式锁定表
SHARE UPDATE /允许同时访问表,但阻止用户锁定整个表以进行独占访问
SHARE ROW EXCLUSIVE /用户可以查看表中的记录,但是无法更新表或锁定SHARE表中的表
EXCLUSIVE /允许查询锁定的表格,但不能进行其他活动
MODE NOWAIT /它指定数据库将等待(达到指定整数的特定秒数)以获取DML锁定
WAIT /它指定数据库将等待(达到指定整数的特定秒数)以获取DML锁定
二、外键创建
在Oracle数据库中,外键是强制实施参照完整性的一种方式,使用外键就意味着一个表中的值在另一个表中也必须出现。被引用的表称为父表,而带有外键的表称为子表。子表中的外键通常会引用父表中的主键
新建一张table1表主键是table1_id 和 table1_name
CREATE TABLE table1
(
table1_id number(10) not null,
table1_name varchar(20) not null,
table1_core varcharq(20),
CONSTRAINT table1_pk PRIMARY KEY (table1_id, table1_name)
);
新建一张table2表外键是table1_id 和 table1_name
CREATE TABLE table2
(
table2_id number(10) not null,
table2_name varchar(20) not null,
table1_id number(10) not null, (外键)
table1_name varchar(20) not null, (外键)
CONSTRAINT table2_comp
FOREIGN KEY (table1_id, table1_name)
REFERENCES table1(table1_id,table1_name)
);
使用ALTER TABLE 创建外键语法
ALTER TABLE table2
ADD CONSTRAINT table1_fk
FOREIGN KEY (table1_id,table1_name)
REFERENCES table1(table1_id,table1_name);
三、MYSQL事务处理
CREATE TABLE table1
(
id number(10) not null,
) engine=innodb ;
engine=mysiam
//MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,
//InnoDB提供事务支持已经外部键等高级数据库功能。
select * from table1;
begin; 开始事
insert into table1 value(100);
insert into table1 value(200);
commit; 提交事务
BEGIN; 开始
insert into table1 value(1);
insert into table1 value(2);
rollback; 回滚
//因为回滚所以数据没有插入
四、MySQL 正则表达式
常用正则表达式(上网搜的额)
匹配中文字符的正则表达式: [\u4e00-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x00-\xff]
匹配空行的正则表达式:\n[\s| ]*\r
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
匹配首尾空格的正则表达式:(^\s*)|(\s*$)
匹配IP地址的正则表达式:/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配网址URL的正则表达式:http://(/[\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
sql语句:^(select|drop|delete|create|update|insert).*$
1、非负整数:^\d+$
2、正整数:^[0-9]*[1-9][0-9]*$
3、非正整数:^((-\d+)|(0+))$
4、负整数:^-[0-9]*[1-9][0-9]*$
5、整数:^-?\d+$
6、非负浮点数:^\d+(\.\d+)?$
7、正浮点数:^((0-9)+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
8、非正浮点数:^((-\d+\.\d+)?)|(0+(\.0+)?))$
9、负浮点数:^(-((正浮点数正则式)))$
10、英文字符串:^[A-Za-z]+$
11、英文大写串:^[A-Z]+$
12、英文小写串:^[a-z]+$
13、英文字符数字串:^[A-Za-z0-9]+$
14、英数字加下划线串:^\w+$
15、E-mail地址:^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$
16、URL:^[a-zA-Z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$
或:^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$
17、邮政编码:^[1-9]\d{5}$
18、中文:^[\u0391-\uFFE5]+$
19、电话号码:^((\d2,3)|(\d{3}\-))?(0\d2,3|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
20、手机号码:^((\d2,3)|(\d{3}\-))?13\d{9}$
21、双字节字符(包括汉字在内):^\x00-\xff
22、匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)
23、匹配HTML标记:<(.*)>.*<\/\1>|<(.*) \/>
24、匹配空行:\n[\s| ]*\r
25、提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
26、提取信息中的邮件地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
27、提取信息中的图片链接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
28、提取信息中的IP地址:(\d+)\.(\d+)\.(\d+)\.(\d+)
29、提取信息中的中国手机号码:(86)*0*13\d{9}
30、提取信息中的中国固定电话号码:(\d3,4|\d{3,4}-|\s)?\d{8}
31、提取信息中的中国电话号码(包括移动和固定电话):(\d3,4|\d{3,4}-|\s)?\d{7,14}
32、提取信息中的中国邮政编码:[1-9]{1}(\d+){5}
33、提取信息中的浮点数(即小数):(-?\d*)\.?\d+
34、提取信息中的任何数字 :(-?\d*)(\.\d+)?
35、IP:(\d+)\.(\d+)\.(\d+)\.(\d+)
36、电话区号:/^0\d{2,3}$/
37、腾讯QQ号:^[1-9]*[1-9][0-9]*$
38、帐号(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
39、中文、英文、数字及下划线:^[\u4e00-\u9fa5_a-zA-Z0-9]+$