You can pin columns by setting the pinned attribute on the column definition to either 'left' or 'right'.
columnDefs: [
    { field: 'athlete', pinned: 'left' }
],Below shows an example with two pinned columns on the left and one pinned column on the right. The example also demonstrates changing the pinning via the API at runtime.
The grid will reorder the columns so that 'left pinned' columns come first and 'right pinned' columns come last. In the example below the state of pinned columns impacts the order of the columns such that when 'Country' is pinned, it jumps to the first position.
 Pinning via Column Dragging Copy Link  
It is possible to pin a column by moving the column in the following ways:
- When other columns are pinned, drag the column to the existing pinned area.
- When no columns are pinned, drag the column to the edge of the grid and wait for approximately one second. The grid will then assume you want to pin and create a pinned area and place the column into it.
 Resizing Pinned Sections Copy Link  
When resizing pinned columns, the size of the pinned sections (left and right) will be limited to the size of the  grid - 50px. This will prevent the center viewport of the grid from becoming inaccessible. For the same reason, if columns that are too wide become pinned, the grid will automatically unpin columns from the pinned sections to make the center viewport visible again. To customise the columns being unpinned, provide the grid option processUnpinnedColumns.
| Allows the user to process the columns being removed from the pinned section because the viewport is too small to accommodate them.
Returns an array of columns to be removed from the pinned areas. | 
 Lock Pinned Copy Link  
If you do not want the user to be able to pin using the UI, set the property lockPinned=true. This will block the UI in the following way:
- Dragging a column to the pinned section will not pin the column.
- For AG Grid Enterprise, the column menu will not have a pin option.
The example below demonstrates columns with pinning locked. The following can be noted:
- The column Athlete is pinned via the configuration and has lockPinned=true. This means the column will be pinned always, it is not possible to drag the column out of the pinned section.
- The column Age is not pinned and has lockPinned=true. This means the column cannot be pinned by dragging the column.
- All other columns act as normal. They can be added and removed from the pinned section by dragging.