Yii-데이터 액세스 개체
실행하려면 SQL query, 다음 단계를 따라야합니다.
- SQL 쿼리를 사용 하여 yii \ db \ Command 를 만듭니다 .
- 바인드 매개 변수 (필수 아님)
- 명령을 실행하십시오.
Step 1 −라는 함수 생성 actionTestDb SiteController에서.
public function actionTestDb(){
// return a set of rows. each row is an associative array of column names and values.
// an empty array is returned if the query returned no results
$users = Yii::$app->db->createCommand('SELECT * FROM user LIMIT 5')
->queryAll();
var_dump($users); // return a single row (the first row) // false is returned if the query has no result $user = Yii::$app->db->createCommand('SELECT * FROM user WHERE id=1') ->queryOne(); var_dump($user);
// return a single column (the first column)
// an empty array is returned if the query returned no results
$userName = Yii::$app->db->createCommand('SELECT name FROM user')
->queryColumn();
var_dump($userName); // return a scalar value // false is returned if the query has no result $count = Yii::$app->db->createCommand('SELECT COUNT(*) FROM user') ->queryScalar(); var_dump($count);
}
위의 예는 DB에서 데이터를 가져 오는 다양한 방법을 보여줍니다.
Step 2 − 주소로 이동 http://localhost:8080/index.php?r=site/test-db, 다음 출력이 표시됩니다.
SQL 명령 생성
매개 변수가있는 SQL 명령을 생성하려면 항상 매개 변수 바인딩 방식을 사용하여 SQL 주입을 방지해야합니다.
Step 1 − 수정 actionTestDb 이 방법으로.
public function actionTestDb() {
$firstUser = Yii::$app->db->createCommand('SELECT * FROM user WHERE id = :id')
->bindValue(':id', 1)
->queryOne();
var_dump($firstUser); $params = [':id' => 2, ':name' => 'User2'];
$secondUser = Yii::$app->db->createCommand('SELECT * FROM user WHERE
id = :id AND name = :name')
->bindValues($params) ->queryOne(); var_dump($secondUser);
//another approach
$params = [':id' => 3, ':name' => 'User3']; $thirdUser = Yii::$app->db->createCommand('SELECT * FROM user WHERE id = :id AND name = :name', $params)
->queryOne();
var_dump($thirdUser);
}
위의 코드에서-
bindValue() − 단일 매개 변수 값을 바인딩합니다.
bindValues() − 여러 매개 변수 값을 바인딩합니다.
Step 2 − 주소로 가면 http://localhost:8080/index.php?r=site/test-db, 다음 출력이 표시됩니다.
INSERT, UPDATE 및 DELETE 쿼리
INSERT, UPDATE 및 DELETE 쿼리의 경우 insert (), update () 및 delete () 메서드를 호출 할 수 있습니다.
Step 1 − 수정 actionTestDb 이 방법으로.
public function actionTestDb() {
public function actionTestDb(){
// INSERT (table name, column values)
Yii::$app->db->createCommand()->insert('user', [
'name' => 'My New User',
'email' => '[email protected]',
])->execute();
$user = Yii::$app->db->createCommand('SELECT * FROM user WHERE name = :name')
->bindValue(':name', 'My New User')
->queryOne();
var_dump($user); // UPDATE (table name, column values, condition) Yii::$app->db->createCommand()->update('user', ['name' => 'My New User
Updated'], 'name = "My New User"')->execute();
$user = Yii::$app->db->createCommand('SELECT * FROM user WHERE name = :name')
->bindValue(':name', 'My New User Updated')
->queryOne();
var_dump($user); // DELETE (table name, condition) Yii::$app->db->createCommand()->delete('user', 'name = "My New User
Updated"')->execute();
$user = Yii::$app->db->createCommand('SELECT * FROM user WHERE name = :name')
->bindValue(':name', 'My New User Updated')
->queryOne();
var_dump($user);
}
}
Step 2 − URL 입력 http://localhost:8080/index.php?r=site/test-db 웹 브라우저의 주소 표시 줄에 다음과 같은 출력이 표시됩니다.