本文实例讲述了PHP封装的MSSql操作类。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
<?php /*MSSql的操作类*/ class MSSql { var $link ; var $querynum = 0; /*连接MSSql数据库,参数:dbsn->数据库服务器地址,dbun->登陆用户名,dbpw->登陆密码,dbname->数据库名字*/ function Connect( $dbsn , $dbun , $dbpw , $dbname ) { if ( $this ->link = @mssql_connect( $dbsn , $dbun , $dbpw , true)) { $query = $this ->Query( 'SET TEXTSIZE 2147483647' ); if (@mssql_select_db( $dbname , $this ->link)) { } else { $this ->halt( 'Can not Select DataBase' ); } } else { $this ->halt( 'Can not connect to MSSQL server' ); } } /*执行sql语句,返回对应的结果标识*/ function Query( $sql ) { if ( $query = @mssql_query( $sql , $this ->link)) { $this ->querynum++; return $query ; } else { $this ->querynum++; $this ->halt( 'MSSQL Query Error' , $sql ); } } /*执行Insert Into语句,并返回最后的insert操作所产生的自动增长的id*/ function Insert( $table , $iarr ) { $value = $this ->InsertSql( $iarr ); $query = $this ->Query( 'INSERT INTO ' . $table . ' ' . $value . '; SELECT SCOPE_IDENTITY() AS [insertid];' ); $record = $this ->GetRow( $query ); $this ->Clear( $query ); return $record [ 'insertid' ]; } /*执行Update语句,并返回最后的update操作所影响的行数*/ function Update( $table , $uarr , $condition = '' ) { $value = $this ->UpdateSql( $uarr ); if ( $condition ) { $condition = ' WHERE ' . $condition ; } $query = $this ->Query( 'UPDATE ' . $table . ' SET ' . $value . $condition . '; SELECT @@ROWCOUNT AS [rowcount];' ); $record = $this ->GetRow( $query ); $this ->Clear( $query ); return $record [ 'rowcount' ]; } /*执行Delete语句,并返回最后的Delete操作所影响的行数*/ function Delete ( $table , $condition = '' ) { if ( $condition ) { $condition = ' WHERE ' . $condition ; } $query = $this ->Query( 'DELETE ' . $table . $condition . '; SELECT @@ROWCOUNT AS [rowcount];' ); $record = $this ->GetRow( $query ); $this ->Clear( $query ); return $record [ 'rowcount' ]; } /*将字符转为可以安全保存的mssql值,比如a'a转为a''a*/ function EnCode( $str ) { return str_replace ( '' ', ' '' ', str_replace(' ', ' ', $str )); } /*将可以安全保存的mssql值转为正常的值,比如a''a转为a'a*/ function DeCode( $str ) { return str_replace ( '' '' , '' ', $str ); } /*将对应的列和值生成对应的insert语句,如:array('id' => 1, 'name' => 'name')返回([id], [name]) VALUES (1, 'name')*/ function InsertSql( $iarr ) { if ( is_array ( $iarr )) { $fstr = '' ; $vstr = '' ; foreach ( $iarr as $key => $val ) { $fstr .= '[' . $key . '], ' ; $vstr .= '' ' . $val . ' ', ' ; } if ( $fstr ) { $fstr = '(' . substr ( $fstr , 0, -2) . ')' ; $vstr = '(' . substr ( $vstr , 0, -2) . ')' ; return $fstr . ' VALUES ' . $vstr ; } else { return '' ; } } else { return '' ; } } /*将对应的列和值生成对应的insert语句,如:array('id' => 1, 'name' => 'name')返回[id] = 1, [name] = 'name'*/ function UpdateSql( $uarr ) { if ( is_array ( $uarr )) { $ustr = '' ; foreach ( $uarr as $key => $val ) { $ustr .= '[' . $key . '] = ' ' . $val . ' ', ' ; } if ( $ustr ) { return substr ( $ustr , 0, -2); } else { return '' ; } } else { return '' ; } } /*返回对应的查询标识的结果的一行*/ function GetRow( $query , $result_type = MSSQL_ASSOC) { return mssql_fetch_array( $query , $result_type ); } /*清空查询结果所占用的内存资源*/ function Clear( $query ) { return mssql_free_result( $query ); } /*关闭数据库*/ function Close() { return mssql_close( $this ->link); } function halt( $message = '' , $sql = '' ) { $message .= '<br />MSSql Error:' . mssql_get_last_message(); if ( $sql ) { $sql = '<br />sql:' . $sql ; } exit ( "DataBase Error.<br />Message $message $sql" ); } } ?> |
希望本文所述对大家PHP程序设计有所帮助。