찾다
백엔드 개발PHP 튜토리얼PHP PDO 캡슐화된 정적 클래스 코드 공유

  1. /**
  2. * 클래스 DB
  3. * 데이터베이스 연산 클래스
  4. */
  5. 클래스 DB {
  6. /**
  7. * @var
  8. * @return CDB
  9. */
  10. 개인 정적 $db;
  11. /**CDb 클래스 가져오기
  12. * @param $table_name 테이블 이름
  13. * @param string $db_setting 호출 데이터베이스 구성 항목
  14. * @param array $db_config 데이터베이스 구성
  15. * @return CDb
  16. */
  17. 공용 정적 함수 cdb($table_name='',$db_setting='default',$db_config=array()){
  18. if(!isset(self: :$db)){
  19. $db = 새 CDb($table_name,$db_setting,$db_config);
  20. self::$db=$db;
  21. }else{
  22. $db=self::$db;
  23. }
  24. $db를 반환합니다.
  25. }
  26. /**구성
  27. * @param $table_name 테이블 이름
  28. * @param string $db_setting 호출 데이터베이스 구성 항목
  29. * @param array $db_config 데이터베이스 구성
  30. * @return CDb
  31. */
  32. 공용 정적 함수 init($table_name='',$db_setting='default',$db_config=array()) {
  33. self 반환: :cdb($table_name,$db_setting,$db_config);
  34. }
  35. /**
  36. * 레코드 삭제 작업 실행
  37. * @param $table 테이블 이름
  38. * @param $condition 데이터 조건을 삭제하며 비워 둘 수 없습니다. 배열일 수 있음
  39. * @return boolean
  40. */
  41. 공용 정적 함수 delete($table, $condition) {
  42. $db=self::cdb();
  43. $db->setTableName($table);
  44. return $db->delete($condition);
  45. }
  46. /**
  47. * 执行添加记录操작품
  48. * @param $table 表name称
  49. * @param array $data要增加的数据,参数为数组。陣列key為欄位值,陣列值為資料取值
  50. * @param bool $return_insert_id 是否傳回新ID號碼
  51. * @param bool $replace 是否採用replace into的方式新增資料
  52. * @return boolean
  53. */
  54. public static function insert($table, $data, $return_insert_id = false, $replace = false) {
  55. $db=self::cdb();
  56. $db-> setTableName($table);
  57. return $db->insert($data, $return_insert_id, $replace);
  58. }
  59. /**
  60. * 取得最後一次新增記錄的主鍵號碼
  61. * @return int
  62. */
  63. public static function insertID() {
  64. $db=self::cdb();
  65. return $db->insert_id();
  66. }
  67. /**
  68. * 執行更新記錄操作
  69. * @param $table 表名稱
  70. * @param $data 要更新的資料內容,參數為數組
  71. * 為數組時數組key為字段值,數組值為資料取值
  72. * 為陣列時[例: array('name'=>'lanmps','password'=>'123456')]
  73. * 陣列的另一種使用array('name' =>' =1', 'base'=>'-=1');程式會自動解析為`name` = `name` 1, `base` = `base` - 1
  74. * 字串,請依照格式:
  75. * 字串[例2:array('catid=:catid AND time>=:time ',array(':catid'=>10,':time'=>'2012-02-10 ')) ]
  76. * @param $where 更新資料時的條件,
  77. * 字串,請依照格式:
  78. * 字串[例1:" id=1 and time>$time " ]
  79. * 字串[例2:array('catid=:catid AND time>=:time ',array(':catid'=>10,':time'=>'2012-02-10')) ]
  80. * 陣列時[例: array('name'=>'lanmps','password'=>'123456')]
  81. * @return boolean
  82. */ bbs.it-home.org
  83. public static function update($table, $data, $where) {
  84. $db=self::cdb();
  85. $db->setTableName($table);
  86. return $db-> update($data,$where);
  87. }
  88. /**
  89. * 取得單一記錄查詢
  90. * @param array $sql 查詢條件語句
  91. * @return array/null資料查詢結果集,如果不存在,則傳回空
  92. */
  93. public static function fetchFirst($sql) {
  94. $db=self::cdb();
  95. return $db->fetch($sql);
  96. }
  97. /**
  98. * 執行sql查詢
  99. * @param $sql查詢條件
  100. * @return array 查詢結果集數組
  101. */
  102. public static function fetchAll($sql) {
  103. $db=self::cdb ();
  104. return $db->fetchAll($sql);
  105. }
  106. /**
  107. * 直接執行sql查詢
  108. * @param $sql 查詢sql語句
  109. * @return
  110. */
  111. public static function query($sql) {
  112. $db= self::cdb();
  113. return $db->e​​xec($sql);
  114. }
  115. /**
  116. * 執行sql查詢
  117. * @param $table 表名稱
  118. * @param $where 查詢條件
  119. * 字串,請依照格式:
  120. * 字串[例1:" id =1 and time>$time " ]
  121. * 字串[例2:array('catid=:catid AND time>=:time ',array(':catid'=>10,':time'=> '2012-02-10')) ]
  122. * 陣列時[例: array('name'=>'lanmps','password'=>'123456')]
  123. * @param $fields需要查詢的欄位值[例`name`,`gender`,`birthday`]
  124. * @param $limit 傳回結果範圍[例:10或10,10 預設為空]
  125. * @param $order 排序方式[預設以資料庫預設方式排序]
  126. * @param $group 分組方式[預設為空]
  127. * @return array 查詢結果集陣列
  128. */
  129. public static function select($table,$where = '', $fields = '*', $limit = '', $order = '', $group = '') {
  130. $db=self::cdb();
  131. $db->setTableName ($table);
  132. return $db->select($where , $fields , $limit, $order , $group);
  133. }
  134. /**
  135. * 取得單一記錄查詢
  136. * @param $table 表名稱
  137. * @param array $where查詢條件語句
  138. * 字串,請依照格式:
  139. * 字串[例2 :array('catid=:catid AND time>=:time ',array(':catid'=>10,':time'=>'2012-02-10')) ]
  140. * 陣列時[例: array('name'=>'lanmps','password'=>'123456')]
  141. * @param string $fields 需要查詢的欄位值[例`name`,`gender`,`birthday`]
  142. * @param string $order 排序方式[預設以資料庫預設方式排序]
  143. * @param string $group 分組方式[預設為空]
  144. * @return array/null資料查詢結果集,如果不存在,則回傳空
  145. */
  146. public static function getOne($table,$where,$fields = '*', $order = '', $group = '') {
  147. $db=self::cdb();
  148. $db-> setTableName($table);
  149. return $db->get_one($where , $fields,$order, $group);
  150. }
  151. /**
  152. * 여러 데이터 쿼리 및 페이지 매기기
  153. * @param $table 테이블 이름
  154. * @param $where 쿼리 조건
  155. * 문자열, 다음 형식을 따르세요.
  156. * 문자열 [예 1 :" id=1 and time>$time " ]
  157. * String [예 2: array('catid=:catid AND time>=:time ',array(':catid'=>10,': time '=>'2012-02-10')) ]
  158. * 배열 [예: array('name'=>'lanmps','password'=>'123456')]
  159. * @ param $fields field*,id
  160. * @param $order 정렬 id desc, orderlist asc
  161. * @param $page 페이지 번호 1
  162. * @param $pagesize 페이지당 항목 수
  163. * @ return array('data'=>data,'count'=>총 레코드 수)
  164. */
  165. 공용 정적 함수 listInfo($table,$where = '',$fields='*', $order = '', $page = 1, $pagesize = 20 ) {
  166. $db=self::cdb();
  167. $db->setTableName($table);
  168. $d=$db->listinfo($where,$fields, $order, $page, $pagesize);
  169. return array('data'=>$d,'count'=>self::$db->number);
  170. }
  171. /**첫 번째 매개변수 값
  172. * @param $sql
  173. * @return 혼합
  174. */
  175. 공용 정적 함수 resultFirst($sql){
  176. $db=self::cdb();
  177. return $db->resultFirst($sql);
  178. }
  179. }
复代码

调사용 방법:

DB::insert('test',array('name'=>'test'));


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP를 사용하여 이메일을 보내는 가장 좋은 방법은 무엇입니까?PHP를 사용하여 이메일을 보내는 가장 좋은 방법은 무엇입니까?May 08, 2025 am 12:21 AM

TheBesteptroachForendingeMailsInphPisusingThephPmailerlibraryDuetoitsReliability, featurerichness 및 reaseofuse.phpmailersupportssmtp, proversDetailErrorHandling, supportSattachments, andenhancessecurity.foroptimalu

PHP의 종속성 주입을위한 모범 사례PHP의 종속성 주입을위한 모범 사례May 08, 2025 am 12:21 AM

의존성 주입 (DI)을 사용하는 이유는 코드의 느슨한 커플 링, 테스트 가능성 및 유지 관리 가능성을 촉진하기 때문입니다. 1) 생성자를 사용하여 종속성을 주입하고, 2) 서비스 로케이터 사용을 피하고, 3) 종속성 주입 컨테이너를 사용하여 종속성을 관리하고, 4) 주입 종속성을 통한 테스트 가능성을 향상 시키십시오.

PHP 성능 튜닝 팁 및 요령PHP 성능 튜닝 팁 및 요령May 08, 2025 am 12:20 AM

phpperformancetuningiscrucialbecauseitenhancesspeedandefficies, thearevitalforwebapplications.1) cachingsdatabaseloadandimprovesResponsetimes.2) 최적화 된 databasequerieseiesecessarycolumnsingpeedsupedsupeveval.

PHP 이메일 보안 : 이메일 보내기 모범 사례PHP 이메일 보안 : 이메일 보내기 모범 사례May 08, 2025 am 12:16 AM

theBestPracticesForendingEmailsSecurelyPinphPinclude : 1) usingecureconfigurations와 whithsmtpandstarttlSencryption, 2) 검증 및 inputSpreverventInseMeStacks, 3) 암호화에 대한 암호화와 비도시를 확인합니다

성능을 위해 PHP 응용 프로그램을 어떻게 최적화합니까?성능을 위해 PHP 응용 프로그램을 어떻게 최적화합니까?May 08, 2025 am 12:08 AM

tooptimizephPapplicationsperperperperperperperperperferferferferferferferferferferperferferperferperperferferfercations.1) ubsicationScachingwithApcuTeDucedAtaFetchTimes.2) 최적화 된 ABASEABASES.3)

PHP의 종속성 주입이란 무엇입니까?PHP의 종속성 주입이란 무엇입니까?May 07, 2025 pm 03:09 PM

expendencyInphpisaDesignpatternpattern thatenhances-flexibility, testability 및 maintainabilitable externaldenciestoclasses.itallowsforloosecoupling, easiertesting throughmocking 및 modulardesign, berrequirecarefultructuringtoavoid-inje

최고의 PHP 성능 최적화 기술최고의 PHP 성능 최적화 기술May 07, 2025 pm 03:05 PM

PHP 성능 최적화는 다음 단계를 통해 달성 할 수 있습니다. 1) 스크립트 상단에 require_once 또는 include_once를 사용하여 파일로드 수를 줄입니다. 2) 데이터베이스 쿼리 수를 줄이기 위해 전처리 문 및 배치 처리를 사용하십시오. 3) Opcode 캐시에 대한 Opcache 구성; 4) PHP-FPM 최적화 프로세스 관리를 활성화하고 구성합니다. 5) CDN을 사용하여 정적 자원을 배포합니다. 6) 코드 성능 분석을 위해 Xdebug 또는 Blackfire를 사용하십시오. 7) 배열과 같은 효율적인 데이터 구조를 선택하십시오. 8) 최적화 실행을위한 모듈 식 코드를 작성하십시오.

PHP 성능 최적화 : Opcode 캐싱 사용PHP 성능 최적화 : Opcode 캐싱 사용May 07, 2025 pm 02:49 PM

opCodeCachingsIntIficInlyIntImeRimproveSphpperformanceCachingCompileDCode, retingServerLoadandResponsEtimes.1) itStoresCompyledPhpCodeInMemory, BYPASSINGPARSINGCOMPILING.2) UseOpCacheSettingParametersInphP.Ini, likeMoryConsAncme AD

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구